/*
 * Raphael 1.5.2 - JavaScript Vector Library
 *
 * Copyright (c) 2010 Dmitry Baranovskiy (http://raphaeljs.com)
 * Licensed under the MIT (http://raphaeljs.com/license.html) license.
 */
(function() {
	function a() {
		if (a.is(arguments[0], G)) {
			var b = arguments[0], d = bV[m](a, b.splice(0, 3 + a.is(b[0], E))), e = d
					.set();
			for ( var g = 0, h = b[w]; g < h; g++) {
				var i = b[g] || {};
				c[f](i.type) && e[L](d[i.type]().attr(i))
			}
			return e
		}
		return bV[m](a, arguments)
	}
	a.version = "1.5.2";
	var b = /[, ]+/, c = {
		circle : 1,
		rect : 1,
		path : 1,
		ellipse : 1,
		text : 1,
		image : 1
	}, d = /\{(\d+)\}/g, e = "prototype", f = "hasOwnProperty", g = document, h = window, i = {
		was : Object[e][f].call(h, "Raphael"),
		is : h.Raphael
	}, j = function() {
		this.customAttributes = {}
	}, k, l = "appendChild", m = "apply", n = "concat", o = "createTouch" in g, p = "", q = " ", r = String, s = "split", t = "click dblclick mousedown mousemove mouseout mouseover mouseup touchstart touchmove touchend orientationchange touchcancel gesturestart gesturechange gestureend"[s]
			(q), u = {
		mousedown : "touchstart",
		mousemove : "touchmove",
		mouseup : "touchend"
	}, v = "join", w = "length", x = r[e].toLowerCase, y = Math, z = y.max, A = y.min, B = y.abs, C = y.pow, D = y.PI, E = "number", F = "string", G = "array", H = "toString", I = "fill", J = Object[e][H], K = {}, L = "push", M = /^url\(['"]?([^\)]+?)['"]?\)$/i, N = /^\s*((#[a-f\d]{6})|(#[a-f\d]{3})|rgba?\(\s*([\d\.]+%?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\)|hsba?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\)|hsla?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\))\s*$/i, O = {
		"NaN" : 1,
		Infinity : 1,
		"-Infinity" : 1
	}, P = /^(?:cubic-)?bezier\(([^,]+),([^,]+),([^,]+),([^\)]+)\)/, Q = y.round, R = "setAttribute", S = parseFloat, T = parseInt, U = " progid:DXImageTransform.Microsoft", V = r[e].toUpperCase, W = {
		blur : 0,
		"clip-rect" : "0 0 1e9 1e9",
		cursor : "default",
		cx : 0,
		cy : 0,
		fill : "#fff",
		"fill-opacity" : 1,
		font : "10px \"Arial\"",
		"font-family" : "\"Arial\"",
		"font-size" : "10",
		"font-style" : "normal",
		"font-weight" : 400,
		gradient : 0,
		height : 0,
		href : "http://raphaeljs.com/",
		opacity : 1,
		path : "M0,0",
		r : 0,
		rotation : 0,
		rx : 0,
		ry : 0,
		scale : "1 1",
		src : "",
		stroke : "#000",
		"stroke-dasharray" : "",
		"stroke-linecap" : "butt",
		"stroke-linejoin" : "butt",
		"stroke-miterlimit" : 0,
		"stroke-opacity" : 1,
		"stroke-width" : 1,
		target : "_blank",
		"text-anchor" : "middle",
		title : "Raphael",
		translation : "0 0",
		width : 0,
		x : 0,
		y : 0
	}, X = {
		along : "along",
		blur : E,
		"clip-rect" : "csv",
		cx : E,
		cy : E,
		fill : "colour",
		"fill-opacity" : E,
		"font-size" : E,
		height : E,
		opacity : E,
		path : "path",
		r : E,
		rotation : "csv",
		rx : E,
		ry : E,
		scale : "csv",
		stroke : "colour",
		"stroke-opacity" : E,
		"stroke-width" : E,
		translation : "csv",
		width : E,
		x : E,
		y : E
	}, Y = "replace", Z = /^(from|to|\d+%?)$/, $ = /\s*,\s*/, _ = {
		hs : 1,
		rg : 1
	}, ba = /,?([achlmqrstvxz]),?/gi, bb = /([achlmqstvz])[\s,]*((-?\d*\.?\d*(?:e[-+]?\d+)?\s*,?\s*)+)/ig, bc = /(-?\d*\.?\d*(?:e[-+]?\d+)?)\s*,?\s*/ig, bd = /^r(?:\(([^,]+?)\s*,\s*([^\)]+?)\))?/, be = function(
			a, b) {
		return a.key - b.key
	};
	a.type = h.SVGAngle
			|| g.implementation.hasFeature(
					"http://www.w3.org/TR/SVG11/feature#BasicStructure", "1.1") ? "SVG"
			: "VML";
	if (a.type == "VML") {
		var bf = g.createElement("div"), bg;
		bf.innerHTML = "<v:shape adj=\"1\"/>";
		bg = bf.firstChild;
		bg.style.behavior = "url(#default#VML)";
		if (!(bg && typeof bg.adj == "object"))
			return a.type = null;
		bf = null
	}
	a.svg = !(a.vml = a.type == "VML");
	j[e] = a[e];
	k = j[e];
	a._id = 0;
	a._oid = 0;
	a.fn = {};
	a.is = function(a, b) {
		b = x.call(b);
		if (b == "finite")
			return !O[f](+a);
		return b == "null" && a === null || b == typeof a || b == "object"
				&& a === Object(a) || b == "array" && Array.isArray
				&& Array.isArray(a)
				|| J.call(a).slice(8, -1).toLowerCase() == b
	};
	a.angle = function(b, c, d, e, f, g) {
		{
			if (f == null) {
				var h = b - d, i = c - e;
				if (!h && !i)
					return 0;
				return ((h < 0) * 180 + y.atan(-i / -h) * 180 / D + 360) % 360
			}
			return a.angle(b, c, f, g) - a.angle(d, e, f, g)
		}
	};
	a.rad = function(a) {
		return a % 360 * D / 180
	};
	a.deg = function(a) {
		return a * 180 / D % 360
	};
	a.snapTo = function(b, c, d) {
		d = a.is(d, "finite") ? d : 10;
		if (a.is(b, G)) {
			var e = b.length;
			while (e--)
				if (B(b[e] - c) <= d)
					return b[e]
		} else {
			b = +b;
			var f = c % b;
			if (f < d)
				return c - f;
			if (f > b - d)
				return c - f + b
		}
		return c
	};
	function bh() {
		var a = [], b = 0;
		for (; b < 32; b++)
			a[b] = (~(~(y.random() * 16)))[H](16);
		a[12] = 4;
		a[16] = (a[16] & 3 | 8)[H](16);
		return "r-" + a[v]("")
	}
	a.setWindow = function(a) {
		h = a;
		g = h.document
	};
	var bi = function(b) {
		if (a.vml) {
			var c = /^\s+|\s+$/g, d;
			try {
				var e = new ActiveXObject("htmlfile");
				e.write("<body>");
				e.close();
				d = e.body
			} catch (a) {
				d = createPopup().document.body
			}
			var f = d.createTextRange();
			bi = bm(function(a) {
				try {
					d.style.color = r(a)[Y](c, p);
					var b = f.queryCommandValue("ForeColor");
					b = (b & 255) << 16 | b & 65280 | (b & 16711680) >>> 16;
					return "#" + ("000000" + b[H](16)).slice(-6)
				} catch (a) {
					return "none"
				}
			})
		} else {
			var h = g.createElement("i");
			h.title = "Raphaël Colour Picker";
			h.style.display = "none";
			g.body[l](h);
			bi = bm(function(a) {
				h.style.color = a;
				return g.defaultView.getComputedStyle(h, p).getPropertyValue(
						"color")
			})
		}
		return bi(b)
	}, bj = function() {
		return "hsb(" + [ this.h, this.s, this.b ] + ")"
	}, bk = function() {
		return "hsl(" + [ this.h, this.s, this.l ] + ")"
	}, bl = function() {
		return this.hex
	};
	a.hsb2rgb = function(b, c, d, e) {
		if (a.is(b, "object") && "h" in b && "s" in b && "b" in b) {
			d = b.b;
			c = b.s;
			b = b.h;
			e = b.o
		}
		return a.hsl2rgb(b, c, d / 2, e)
	};
	a.hsl2rgb = function(b, c, d, e) {
		if (a.is(b, "object") && "h" in b && "s" in b && "l" in b) {
			d = b.l;
			c = b.s;
			b = b.h
		}
		if (b > 1 || c > 1 || d > 1) {
			b /= 360;
			c /= 100;
			d /= 100
		}
		var f = {}, g = [ "r", "g", "b" ], h, i, j, k, l, m;
		if (c) {
			d < 0.5 ? h = d * (1 + c) : h = d + c - d * c;
			i = 2 * d - h;
			for ( var n = 0; n < 3; n++) {
				j = b + 1 / 3 * -(n - 1);
				j < 0 && j++;
				j > 1 && j--;
				j * 6 < 1 ? f[g[n]] = i + (h - i) * 6 * j
						: j * 2 < 1 ? f[g[n]] = h : j * 3 < 2 ? f[g[n]] = i
								+ (h - i) * (2 / 3 - j) * 6 : f[g[n]] = i
			}
		} else
			f = {
				r : d,
				g : d,
				b : d
			};
		f.r *= 255;
		f.g *= 255;
		f.b *= 255;
		f.hex = "#"
				+ (16777216 | f.b | f.g << 8 | f.r << 16).toString(16).slice(1);
		a.is(e, "finite") && (f.opacity = e);
		f.toString = bl;
		return f
	};
	a.rgb2hsb = function(b, c, d) {
		if (c == null && a.is(b, "object") && "r" in b && "g" in b && "b" in b) {
			d = b.b;
			c = b.g;
			b = b.r
		}
		if (c == null && a.is(b, F)) {
			var e = a.getRGB(b);
			b = e.r;
			c = e.g;
			d = e.b
		}
		if (b > 1 || c > 1 || d > 1) {
			b /= 255;
			c /= 255;
			d /= 255
		}
		var f = z(b, c, d), g = A(b, c, d), h, i, j = f;
		{
			if (g == f)
				return {
					h : 0,
					s : 0,
					b : f,
					toString : bj
				};
			var k = f - g;
			i = k / f;
			b == f ? h = (c - d) / k : c == f ? h = 2 + (d - b) / k : h = 4
					+ (b - c) / k;
			h /= 6;
			h < 0 && h++;
			h > 1 && h--
		}
		return {
			h : h,
			s : i,
			b : j,
			toString : bj
		}
	};
	a.rgb2hsl = function(b, c, d) {
		if (c == null && a.is(b, "object") && "r" in b && "g" in b && "b" in b) {
			d = b.b;
			c = b.g;
			b = b.r
		}
		if (c == null && a.is(b, F)) {
			var e = a.getRGB(b);
			b = e.r;
			c = e.g;
			d = e.b
		}
		if (b > 1 || c > 1 || d > 1) {
			b /= 255;
			c /= 255;
			d /= 255
		}
		var f = z(b, c, d), g = A(b, c, d), h, i, j = (f + g) / 2, k;
		if (g == f)
			k = {
				h : 0,
				s : 0,
				l : j
			};
		else {
			var l = f - g;
			i = j < 0.5 ? l / (f + g) : l / (2 - f - g);
			b == f ? h = (c - d) / l : c == f ? h = 2 + (d - b) / l : h = 4
					+ (b - c) / l;
			h /= 6;
			h < 0 && h++;
			h > 1 && h--;
			k = {
				h : h,
				s : i,
				l : j
			}
		}
		k.toString = bk;
		return k
	};
	a._path2string = function() {
		return this.join(",")[Y](ba, "$1")
	};
	function bm(a, b, c) {
		function d() {
			var g = Array[e].slice.call(arguments, 0), h = g[v]("►"), i = d.cache = d.cache
					|| {}, j = d.count = d.count || [];
			if (i[f](h))
				return c ? c(i[h]) : i[h];
			j[w] >= 1000 && delete i[j.shift()];
			j[L](h);
			i[h] = a[m](b, g);
			return c ? c(i[h]) : i[h]
		}
		return d
	}
	a.getRGB = bm(function(b) {
		if (!b || !(!((b = r(b)).indexOf("-") + 1)))
			return {
				r : -1,
				g : -1,
				b : -1,
				hex : "none",
				error : 1
			};
		if (b == "none")
			return {
				r : -1,
				g : -1,
				b : -1,
				hex : "none"
			};
		!(_[f](b.toLowerCase().substring(0, 2)) || b.charAt() == "#")
				&& (b = bi(b));
		var c, d, e, g, h, i, j, k = b.match(N);
		if (k) {
			if (k[2]) {
				g = T(k[2].substring(5), 16);
				e = T(k[2].substring(3, 5), 16);
				d = T(k[2].substring(1, 3), 16)
			}
			if (k[3]) {
				g = T((i = k[3].charAt(3)) + i, 16);
				e = T((i = k[3].charAt(2)) + i, 16);
				d = T((i = k[3].charAt(1)) + i, 16)
			}
			if (k[4]) {
				j = k[4][s]($);
				d = S(j[0]);
				j[0].slice(-1) == "%" && (d *= 2.55);
				e = S(j[1]);
				j[1].slice(-1) == "%" && (e *= 2.55);
				g = S(j[2]);
				j[2].slice(-1) == "%" && (g *= 2.55);
				k[1].toLowerCase().slice(0, 4) == "rgba" && (h = S(j[3]));
				j[3] && j[3].slice(-1) == "%" && (h /= 100)
			}
			if (k[5]) {
				j = k[5][s]($);
				d = S(j[0]);
				j[0].slice(-1) == "%" && (d *= 2.55);
				e = S(j[1]);
				j[1].slice(-1) == "%" && (e *= 2.55);
				g = S(j[2]);
				j[2].slice(-1) == "%" && (g *= 2.55);
				(j[0].slice(-3) == "deg" || j[0].slice(-1) == "°")
						&& (d /= 360);
				k[1].toLowerCase().slice(0, 4) == "hsba" && (h = S(j[3]));
				j[3] && j[3].slice(-1) == "%" && (h /= 100);
				return a.hsb2rgb(d, e, g, h)
			}
			if (k[6]) {
				j = k[6][s]($);
				d = S(j[0]);
				j[0].slice(-1) == "%" && (d *= 2.55);
				e = S(j[1]);
				j[1].slice(-1) == "%" && (e *= 2.55);
				g = S(j[2]);
				j[2].slice(-1) == "%" && (g *= 2.55);
				(j[0].slice(-3) == "deg" || j[0].slice(-1) == "°")
						&& (d /= 360);
				k[1].toLowerCase().slice(0, 4) == "hsla" && (h = S(j[3]));
				j[3] && j[3].slice(-1) == "%" && (h /= 100);
				return a.hsl2rgb(d, e, g, h)
			}
			k = {
				r : d,
				g : e,
				b : g
			};
			k.hex = "#"
					+ (16777216 | g | e << 8 | d << 16).toString(16).slice(1);
			a.is(h, "finite") && (k.opacity = h);
			return k
		}
		return {
			r : -1,
			g : -1,
			b : -1,
			hex : "none",
			error : 1
		}
	}, a);
	a.getColor = function(a) {
		var b = this.getColor.start = this.getColor.start || {
			h : 0,
			s : 1,
			b : a || 0.75
		}, c = this.hsb2rgb(b.h, b.s, b.b);
		b.h += 0.075;
		if (b.h > 1) {
			b.h = 0;
			b.s -= 0.2;
			b.s <= 0 && (this.getColor.start = {
				h : 0,
				s : 1,
				b : b.b
			})
		}
		return c.hex
	};
	a.getColor.reset = function() {
		delete this.start
	};
	a.parsePathString = bm(function(b) {
		if (!b)
			return null;
		var c = {
			a : 7,
			c : 6,
			h : 1,
			l : 2,
			m : 2,
			q : 4,
			s : 4,
			t : 2,
			v : 1,
			z : 0
		}, d = [];
		a.is(b, G) && a.is(b[0], G) && (d = bo(b));
		d[w] || r(b)[Y](bb, function(a, b, e) {
			var f = [], g = x.call(b);
			e[Y](bc, function(a, b) {
				b && f[L](+b)
			});
			if (g == "m" && f[w] > 2) {
				d[L]([ b ][n](f.splice(0, 2)));
				g = "l";
				b = b == "m" ? "l" : "L"
			}
			while (f[w] >= c[g]) {
				d[L]([ b ][n](f.splice(0, c[g])));
				if (!c[g])
					break
			}
		});
		d[H] = a._path2string;
		return d
	});
	a.findDotsAtSegment = function(a, b, c, d, e, f, g, h, i) {
		var j = 1 - i, k = C(j, 3) * a + C(j, 2) * 3 * i * c + j * 3 * i * i
				* e + C(i, 3) * g, l = C(j, 3) * b + C(j, 2) * 3 * i * d + j
				* 3 * i * i * f + C(i, 3) * h, m = a + 2 * i * (c - a) + i * i
				* (e - 2 * c + a), n = b + 2 * i * (d - b) + i * i
				* (f - 2 * d + b), o = c + 2 * i * (e - c) + i * i
				* (g - 2 * e + c), p = d + 2 * i * (f - d) + i * i
				* (h - 2 * f + d), q = (1 - i) * a + i * c, r = (1 - i) * b + i
				* d, s = (1 - i) * e + i * g, t = (1 - i) * f + i * h, u = 90
				- y.atan((m - o) / (n - p)) * 180 / D;
		(m > o || n < p) && (u += 180);
		return {
			x : k,
			y : l,
			m : {
				x : m,
				y : n
			},
			n : {
				x : o,
				y : p
			},
			start : {
				x : q,
				y : r
			},
			end : {
				x : s,
				y : t
			},
			alpha : u
		}
	};
	var bn = bm(function(a) {
		if (!a)
			return {
				x : 0,
				y : 0,
				width : 0,
				height : 0
			};
		a = bw(a);
		var b = 0, c = 0, d = [], e = [], f;
		for ( var g = 0, h = a[w]; g < h; g++) {
			f = a[g];
			if (f[0] == "M") {
				b = f[1];
				c = f[2];
				d[L](b);
				e[L](c)
			} else {
				var i = bv(b, c, f[1], f[2], f[3], f[4], f[5], f[6]);
				d = d[n](i.min.x, i.max.x);
				e = e[n](i.min.y, i.max.y);
				b = f[5];
				c = f[6]
			}
		}
		var j = A[m](0, d), k = A[m](0, e);
		return {
			x : j,
			y : k,
			width : z[m](0, d) - j,
			height : z[m](0, e) - k
		}
	}), bo = function(b) {
		var c = [];
		if (!a.is(b, G) || !a.is(b && b[0], G))
			b = a.parsePathString(b);
		for ( var d = 0, e = b[w]; d < e; d++) {
			c[d] = [];
			for ( var f = 0, g = b[d][w]; f < g; f++)
				c[d][f] = b[d][f]
		}
		c[H] = a._path2string;
		return c
	}, bp = bm(function(b) {
		if (!a.is(b, G) || !a.is(b && b[0], G))
			b = a.parsePathString(b);
		var c = [], d = 0, e = 0, f = 0, g = 0, h = 0;
		if (b[0][0] == "M") {
			d = b[0][1];
			e = b[0][2];
			f = d;
			g = e;
			h++;
			c[L]([ "M", d, e ])
		}
		for ( var i = h, j = b[w]; i < j; i++) {
			var k = c[i] = [], l = b[i];
			if (l[0] != x.call(l[0])) {
				k[0] = x.call(l[0]);
				switch (k[0]) {
				case "a":
					k[1] = l[1];
					k[2] = l[2];
					k[3] = l[3];
					k[4] = l[4];
					k[5] = l[5];
					k[6] = +(l[6] - d).toFixed(3);
					k[7] = +(l[7] - e).toFixed(3);
					break;
				case "v":
					k[1] = +(l[1] - e).toFixed(3);
					break;
				case "m":
					f = l[1];
					g = l[2];
				default:
					for ( var m = 1, n = l[w]; m < n; m++)
						k[m] = +(l[m] - (m % 2 ? d : e)).toFixed(3)
				}
			} else {
				k = c[i] = [];
				if (l[0] == "m") {
					f = l[1] + d;
					g = l[2] + e
				}
				for ( var o = 0, p = l[w]; o < p; o++)
					c[i][o] = l[o]
			}
			var q = c[i][w];
			switch (c[i][0]) {
			case "z":
				d = f;
				e = g;
				break;
			case "h":
				d += +c[i][q - 1];
				break;
			case "v":
				e += +c[i][q - 1];
				break;
			default:
				d += +c[i][q - 2];
				e += +c[i][q - 1]
			}
		}
		c[H] = a._path2string;
		return c
	}, 0, bo), bq = bm(function(b) {
		if (!a.is(b, G) || !a.is(b && b[0], G))
			b = a.parsePathString(b);
		var c = [], d = 0, e = 0, f = 0, g = 0, h = 0;
		if (b[0][0] == "M") {
			d = +b[0][1];
			e = +b[0][2];
			f = d;
			g = e;
			h++;
			c[0] = [ "M", d, e ]
		}
		for ( var i = h, j = b[w]; i < j; i++) {
			var k = c[i] = [], l = b[i];
			if (l[0] != V.call(l[0])) {
				k[0] = V.call(l[0]);
				switch (k[0]) {
				case "A":
					k[1] = l[1];
					k[2] = l[2];
					k[3] = l[3];
					k[4] = l[4];
					k[5] = l[5];
					k[6] = +(l[6] + d);
					k[7] = +(l[7] + e);
					break;
				case "V":
					k[1] = +l[1] + e;
					break;
				case "H":
					k[1] = +l[1] + d;
					break;
				case "M":
					f = +l[1] + d;
					g = +l[2] + e;
				default:
					for ( var m = 1, n = l[w]; m < n; m++)
						k[m] = +l[m] + (m % 2 ? d : e)
				}
			} else
				for ( var o = 0, p = l[w]; o < p; o++)
					c[i][o] = l[o];
			switch (k[0]) {
			case "Z":
				d = f;
				e = g;
				break;
			case "H":
				d = k[1];
				break;
			case "V":
				e = k[1];
				break;
			case "M":
				f = c[i][c[i][w] - 2];
				g = c[i][c[i][w] - 1];
			default:
				d = c[i][c[i][w] - 2];
				e = c[i][c[i][w] - 1]
			}
		}
		c[H] = a._path2string;
		return c
	}, null, bo), br = function(a, b, c, d) {
		return [ a, b, c, d, c, d ]
	}, bs = function(a, b, c, d, e, f) {
		var g = 1 / 3, h = 2 / 3;
		return [ g * a + h * c, g * b + h * d, g * e + h * c, g * f + h * d, e,
				f ]
	}, bt = function(a, b, c, d, e, f, g, h, i, j) {
		var k = D * 120 / 180, l = D / 180 * (+e || 0), m = [], o, p = bm(function(
				a, b, c) {
			var d = a * y.cos(c) - b * y.sin(c), e = a * y.sin(c) + b
					* y.cos(c);
			return {
				x : d,
				y : e
			}
		});
		if (j) {
			G = j[0];
			H = j[1];
			E = j[2];
			F = j[3]
		} else {
			o = p(a, b, -l);
			a = o.x;
			b = o.y;
			o = p(h, i, -l);
			h = o.x;
			i = o.y;
			var q = y.cos(D / 180 * e), r = y.sin(D / 180 * e), t = (a - h) / 2, u = (b - i) / 2, x = t
					* t / (c * c) + u * u / (d * d);
			if (x > 1) {
				x = y.sqrt(x);
				c = x * c;
				d = x * d
			}
			var z = c * c, A = d * d, C = (f == g ? -1 : 1)
					* y.sqrt(B((z * A - z * u * u - A * t * t)
							/ (z * u * u + A * t * t))), E = C * c * u / d
					+ (a + h) / 2, F = C * -d * t / c + (b + i) / 2, G = y
					.asin(((b - F) / d).toFixed(9)), H = y.asin(((i - F) / d)
					.toFixed(9));
			G = a < E ? D - G : G;
			H = h < E ? D - H : H;
			G < 0 && (G = D * 2 + G);
			H < 0 && (H = D * 2 + H);
			g && G > H && (G = G - D * 2);
			!g && H > G && (H = H - D * 2)
		}
		var I = H - G;
		if (B(I) > k) {
			var J = H, K = h, L = i;
			H = G + k * (g && H > G ? 1 : -1);
			h = E + c * y.cos(H);
			i = F + d * y.sin(H);
			m = bt(h, i, c, d, e, 0, g, K, L, [ H, J, E, F ])
		}
		I = H - G;
		var M = y.cos(G), N = y.sin(G), O = y.cos(H), P = y.sin(H), Q = y
				.tan(I / 4), R = 4 / 3 * c * Q, S = 4 / 3 * d * Q, T = [ a, b ], U = [
				a + R * N, b - S * M ], V = [ h + R * P, i - S * O ], W = [ h,
				i ];
		U[0] = 2 * T[0] - U[0];
		U[1] = 2 * T[1] - U[1];
		{
			if (j)
				return [ U, V, W ][n](m);
			m = [ U, V, W ][n](m)[v]()[s](",");
			var X = [];
			for ( var Y = 0, Z = m[w]; Y < Z; Y++)
				X[Y] = Y % 2 ? p(m[Y - 1], m[Y], l).y : p(m[Y], m[Y + 1], l).x;
			return X
		}
	}, bu = function(a, b, c, d, e, f, g, h, i) {
		var j = 1 - i;
		return {
			x : C(j, 3) * a + C(j, 2) * 3 * i * c + j * 3 * i * i * e + C(i, 3)
					* g,
			y : C(j, 3) * b + C(j, 2) * 3 * i * d + j * 3 * i * i * f + C(i, 3)
					* h
		}
	}, bv = bm(function(a, b, c, d, e, f, g, h) {
		var i = e - 2 * c + a - (g - 2 * e + c), j = 2 * (c - a) - 2 * (e - c), k = a
				- c, l = (-j + y.sqrt(j * j - 4 * i * k)) / 2 / i, n = (-j - y
				.sqrt(j * j - 4 * i * k))
				/ 2 / i, o = [ b, h ], p = [ a, g ], q;
		B(l) > "1e12" && (l = 0.5);
		B(n) > "1e12" && (n = 0.5);
		if (l > 0 && l < 1) {
			q = bu(a, b, c, d, e, f, g, h, l);
			p[L](q.x);
			o[L](q.y)
		}
		if (n > 0 && n < 1) {
			q = bu(a, b, c, d, e, f, g, h, n);
			p[L](q.x);
			o[L](q.y)
		}
		i = f - 2 * d + b - (h - 2 * f + d);
		j = 2 * (d - b) - 2 * (f - d);
		k = b - d;
		l = (-j + y.sqrt(j * j - 4 * i * k)) / 2 / i;
		n = (-j - y.sqrt(j * j - 4 * i * k)) / 2 / i;
		B(l) > "1e12" && (l = 0.5);
		B(n) > "1e12" && (n = 0.5);
		if (l > 0 && l < 1) {
			q = bu(a, b, c, d, e, f, g, h, l);
			p[L](q.x);
			o[L](q.y)
		}
		if (n > 0 && n < 1) {
			q = bu(a, b, c, d, e, f, g, h, n);
			p[L](q.x);
			o[L](q.y)
		}
		return {
			min : {
				x : A[m](0, p),
				y : A[m](0, o)
			},
			max : {
				x : z[m](0, p),
				y : z[m](0, o)
			}
		}
	}), bw = bm(function(a, b) {
		var c = bq(a), d = b && bq(b), e = {
			x : 0,
			y : 0,
			bx : 0,
			by : 0,
			X : 0,
			Y : 0,
			qx : null,
			qy : null
		}, f = {
			x : 0,
			y : 0,
			bx : 0,
			by : 0,
			X : 0,
			Y : 0,
			qx : null,
			qy : null
		}, g = function(a, b) {
			var c, d;
			if (!a)
				return [ "C", b.x, b.y, b.x, b.y, b.x, b.y ];
			!(a[0] in {
				T : 1,
				Q : 1
			}) && (b.qx = b.qy = null);
			switch (a[0]) {
			case "M":
				b.X = a[1];
				b.Y = a[2];
				break;
			case "A":
				a = [ "C" ][n](bt[m](0, [ b.x, b.y ][n](a.slice(1))));
				break;
			case "S":
				c = b.x + (b.x - (b.bx || b.x));
				d = b.y + (b.y - (b.by || b.y));
				a = [ "C", c, d ][n](a.slice(1));
				break;
			case "T":
				b.qx = b.x + (b.x - (b.qx || b.x));
				b.qy = b.y + (b.y - (b.qy || b.y));
				a = [ "C" ][n](bs(b.x, b.y, b.qx, b.qy, a[1], a[2]));
				break;
			case "Q":
				b.qx = a[1];
				b.qy = a[2];
				a = [ "C" ][n](bs(b.x, b.y, a[1], a[2], a[3], a[4]));
				break;
			case "L":
				a = [ "C" ][n](br(b.x, b.y, a[1], a[2]));
				break;
			case "H":
				a = [ "C" ][n](br(b.x, b.y, a[1], b.y));
				break;
			case "V":
				a = [ "C" ][n](br(b.x, b.y, b.x, a[1]));
				break;
			case "Z":
				a = [ "C" ][n](br(b.x, b.y, b.X, b.Y));
				break
			}
			return a
		}, h = function(a, b) {
			if (a[b][w] > 7) {
				a[b].shift();
				var e = a[b];
				while (e[w])
					a.splice(b++, 0, [ "C" ][n](e.splice(0, 6)));
				a.splice(b, 1);
				k = z(c[w], d && d[w] || 0)
			}
		}, i = function(a, b, e, f, g) {
			if (a && b && a[g][0] == "M" && b[g][0] != "M") {
				b.splice(g, 0, [ "M", f.x, f.y ]);
				e.bx = 0;
				e.by = 0;
				e.x = a[g][1];
				e.y = a[g][2];
				k = z(c[w], d && d[w] || 0)
			}
		};
		for ( var j = 0, k = z(c[w], d && d[w] || 0); j < k; j++) {
			c[j] = g(c[j], e);
			h(c, j);
			d && (d[j] = g(d[j], f));
			d && h(d, j);
			i(c, d, e, f, j);
			i(d, c, f, e, j);
			var l = c[j], o = d && d[j], p = l[w], q = d && o[w];
			e.x = l[p - 2];
			e.y = l[p - 1];
			e.bx = S(l[p - 4]) || e.x;
			e.by = S(l[p - 3]) || e.y;
			f.bx = d && (S(o[q - 4]) || f.x);
			f.by = d && (S(o[q - 3]) || f.y);
			f.x = d && o[q - 2];
			f.y = d && o[q - 1]
		}
		return d ? [ c, d ] : c
	}, null, bo), bx = bm(function(b) {
		var c = [];
		for ( var d = 0, e = b[w]; d < e; d++) {
			var f = {}, g = b[d].match(/^([^:]*):?([\d\.]*)/);
			f.color = a.getRGB(g[1]);
			if (f.color.error)
				return null;
			f.color = f.color.hex;
			g[2] && (f.offset = g[2] + "%");
			c[L](f)
		}
		for (d = 1, e = c[w] - 1; d < e; d++) {
			if (!c[d].offset) {
				var h = S(c[d - 1].offset || 0), i = 0;
				for ( var j = d + 1; j < e; j++) {
					if (c[j].offset) {
						i = c[j].offset;
						break
					}
				}
				if (!i) {
					i = 100;
					j = e
				}
				i = S(i);
				var k = (i - h) / (j - d + 1);
				for (; d < j; d++) {
					h += k;
					c[d].offset = h + "%"
				}
			}
		}
		return c
	}), by = function(b, c, d, e) {
		var f;
		if (a.is(b, F) || a.is(b, "object")) {
			f = a.is(b, F) ? g.getElementById(b) : b;
			if (f.tagName)
				return c == null ? {
					container : f,
					width : f.style.pixelWidth || f.offsetWidth,
					height : f.style.pixelHeight || f.offsetHeight
				} : {
					container : f,
					width : c,
					height : d
				}
		} else
			return {
				container : 1,
				x : b,
				y : c,
				width : d,
				height : e
			}
	}, bz = function(a, b) {
		var c = this;
		for ( var d in b) {
			if (b[f](d) && !(d in a))
				switch (typeof b[d]) {
				case "function":
					(function(b) {
						a[d] = a === c ? b : function() {
							return b[m](c, arguments)
						}
					})(b[d]);
					break;
				case "object":
					a[d] = a[d] || {};
					bz.call(this, a[d], b[d]);
					break;
				default:
					a[d] = b[d];
					break
				}
		}
	}, bA = function(a, b) {
		a == b.top && (b.top = a.prev);
		a == b.bottom && (b.bottom = a.next);
		a.next && (a.next.prev = a.prev);
		a.prev && (a.prev.next = a.next)
	}, bB = function(a, b) {
		if (b.top === a)
			return;
		bA(a, b);
		a.next = null;
		a.prev = b.top;
		b.top.next = a;
		b.top = a
	}, bC = function(a, b) {
		if (b.bottom === a)
			return;
		bA(a, b);
		a.next = b.bottom;
		a.prev = null;
		b.bottom.prev = a;
		b.bottom = a
	}, bD = function(a, b, c) {
		bA(a, c);
		b == c.top && (c.top = a);
		b.next && (b.next.prev = a);
		a.next = b.next;
		a.prev = b;
		b.next = a
	}, bE = function(a, b, c) {
		bA(a, c);
		b == c.bottom && (c.bottom = a);
		b.prev && (b.prev.next = a);
		a.prev = b.prev;
		b.prev = a;
		a.next = b
	}, bF = function(a) {
		return function() {
			throw new Error("Raphaël: you are calling to method “" + a
					+ "” of removed object")
		}
	};
	a.pathToRelative = bp;
	if (a.svg) {
		k.svgns = "http://www.w3.org/2000/svg";
		k.xlink = "http://www.w3.org/1999/xlink";
		Q = function(a) {
			return +a + (~(~a) === a) * 0.5
		};
		var bG = function(a, b) {
			if (b)
				for ( var c in b)
					b[f](c) && a[R](c, r(b[c]));
			else {
				a = g.createElementNS(k.svgns, a);
				a.style.webkitTapHighlightColor = "rgba(0,0,0,0)";
				return a
			}
		};
		a[H] = function() {
			return "Your browser supports SVG.\nYou are running Raphaël "
					+ this.version
		};
		var bH = function(a, b) {
			var c = bG("path");
			b.canvas && b.canvas[l](c);
			var d = new bN(c, b);
			d.type = "path";
			bK(d, {
				fill : "none",
				stroke : "#000",
				path : a
			});
			return d
		}, bI = function(a, b, c) {
			var d = "linear", e = 0.5, f = 0.5, h = a.style;
			b = r(b)[Y](bd, function(a, b, c) {
				d = "radial";
				if (b && c) {
					e = S(b);
					f = S(c);
					var g = (f > 0.5) * 2 - 1;
					C(e - 0.5, 2) + C(f - 0.5, 2) > 0.25
							&& (f = y.sqrt(0.25 - C(e - 0.5, 2)) * g + 0.5)
							&& f != 0.5 && (f = f.toFixed(5) - 0.00001 * g)
				}
				return p
			});
			b = b[s](/\s*\-\s*/);
			if (d == "linear") {
				var i = b.shift();
				i = -S(i);
				if (isNaN(i))
					return null;
				var j = [ 0, 0, y.cos(i * D / 180), y.sin(i * D / 180) ], k = 1 / (z(
						B(j[2]), B(j[3])) || 1);
				j[2] *= k;
				j[3] *= k;
				if (j[2] < 0) {
					j[0] = -j[2];
					j[2] = 0
				}
				if (j[3] < 0) {
					j[1] = -j[3];
					j[3] = 0
				}
			}
			var m = bx(b);
			if (!m)
				return null;
			var n = a.getAttribute(I);
			n = n.match(/^url\(#(.*)\)$/);
			n && c.defs.removeChild(g.getElementById(n[1]));
			var o = bG(d + "Gradient");
			o.id = bh();
			bG(o, d == "radial" ? {
				fx : e,
				fy : f
			} : {
				x1 : j[0],
				y1 : j[1],
				x2 : j[2],
				y2 : j[3]
			});
			c.defs[l](o);
			for ( var q = 0, t = m[w]; q < t; q++) {
				var u = bG("stop");
				bG(u, {
					offset : m[q].offset ? m[q].offset : q ? "100%" : "0%",
					"stop-color" : m[q].color || "#fff"
				});
				o[l](u)
			}
			bG(a, {
				fill : "url(#" + o.id + ")",
				opacity : 1,
				"fill-opacity" : 1
			});
			h.fill = p;
			h.opacity = 1;
			h.fillOpacity = 1;
			return 1
		}, bJ = function(b) {
			var c = b.getBBox();
			bG(b.pattern, {
				patternTransform : a.format("translate({0},{1})", c.x, c.y)
			})
		}, bK = function(c, d) {
			var e = {
				"" : [ 0 ],
				none : [ 0 ],
				"-" : [ 3, 1 ],
				"." : [ 1, 1 ],
				"-." : [ 3, 1, 1, 1 ],
				"-.." : [ 3, 1, 1, 1, 1, 1 ],
				". " : [ 1, 3 ],
				"- " : [ 4, 3 ],
				"--" : [ 8, 3 ],
				"- ." : [ 4, 3, 1, 3 ],
				"--." : [ 8, 3, 1, 3 ],
				"--.." : [ 8, 3, 1, 3, 1, 3 ]
			}, h = c.node, i = c.attrs, j = c.rotate(), k = function(a, b) {
				b = e[x.call(b)];
				if (b) {
					var c = a.attrs["stroke-width"] || "1", f = ({
						round : c,
						square : c,
						butt : 0
					})[a.attrs["stroke-linecap"] || d["stroke-linecap"]] || 0, g = [], i = b[w];
					while (i--)
						g[i] = b[i] * c + (i % 2 ? 1 : -1) * f;
					bG(h, {
						"stroke-dasharray" : g[v](",")
					})
				}
			};
			d[f]("rotation") && (j = d.rotation);
			var m = r(j)[s](b);
			if (m.length - 1) {
				m[1] = +m[1];
				m[2] = +m[2]
			} else
				m = null;
			S(j) && c.rotate(0, true);
			for ( var n in d) {
				if (d[f](n)) {
					if (!W[f](n))
						continue;
					var o = d[n];
					i[n] = o;
					switch (n) {
					case "blur":
						c.blur(o);
						break;
					case "rotation":
						c.rotate(o, true);
						break;
					case "href":
					case "title":
					case "target":
						var t = h.parentNode;
						if (x.call(t.tagName) != "a") {
							var u = bG("a");
							t.insertBefore(u, h);
							u[l](h);
							t = u
						}
						n == "target" && o == "blank" ? t.setAttributeNS(
								c.paper.xlink, "show", "new") : t
								.setAttributeNS(c.paper.xlink, n, o);
						break;
					case "cursor":
						h.style.cursor = o;
						break;
					case "clip-rect":
						var y = r(o)[s](b);
						if (y[w] == 4) {
							c.clip
									&& c.clip.parentNode.parentNode
											.removeChild(c.clip.parentNode);
							var z = bG("clipPath"), A = bG("rect");
							z.id = bh();
							bG(A, {
								x : y[0],
								y : y[1],
								width : y[2],
								height : y[3]
							});
							z[l](A);
							c.paper.defs[l](z);
							bG(h, {
								"clip-path" : "url(#" + z.id + ")"
							});
							c.clip = A
						}
						if (!o) {
							var B = g.getElementById(h
									.getAttribute("clip-path")[Y](
									/(^url\(#|\)$)/g, p));
							B && B.parentNode.removeChild(B);
							bG(h, {
								"clip-path" : p
							});
							delete c.clip
						}
						break;
					case "path":
						c.type == "path" && bG(h, {
							d : o ? i.path = bq(o) : "M0,0"
						});
						break;
					case "width":
						h[R](n, o);
						if (i.fx) {
							n = "x";
							o = i.x
						} else
							break;
					case "x":
						i.fx && (o = -i.x - (i.width || 0));
					case "rx":
						if (n == "rx" && c.type == "rect")
							break;
					case "cx":
						m && (n == "x" || n == "cx") && (m[1] += o - i[n]);
						h[R](n, o);
						c.pattern && bJ(c);
						break;
					case "height":
						h[R](n, o);
						if (i.fy) {
							n = "y";
							o = i.y
						} else
							break;
					case "y":
						i.fy && (o = -i.y - (i.height || 0));
					case "ry":
						if (n == "ry" && c.type == "rect")
							break;
					case "cy":
						m && (n == "y" || n == "cy") && (m[2] += o - i[n]);
						h[R](n, o);
						c.pattern && bJ(c);
						break;
					case "r":
						c.type == "rect" ? bG(h, {
							rx : o,
							ry : o
						}) : h[R](n, o);
						break;
					case "src":
						c.type == "image"
								&& h.setAttributeNS(c.paper.xlink, "href", o);
						break;
					case "stroke-width":
						h.style.strokeWidth = o;
						h[R](n, o);
						i["stroke-dasharray"] && k(c, i["stroke-dasharray"]);
						break;
					case "stroke-dasharray":
						k(c, o);
						break;
					case "translation":
						var C = r(o)[s](b);
						C[0] = +C[0] || 0;
						C[1] = +C[1] || 0;
						if (m) {
							m[1] += C[0];
							m[2] += C[1]
						}
						cz.call(c, C[0], C[1]);
						break;
					case "scale":
						C = r(o)[s](b);
						c.scale(+C[0] || 1, +C[1] || +C[0] || 1,
								isNaN(S(C[2])) ? null : +C[2],
								isNaN(S(C[3])) ? null : +C[3]);
						break;
					case I:
						var D = r(o).match(M);
						if (D) {
							z = bG("pattern");
							var E = bG("image");
							z.id = bh();
							bG(z, {
								x : 0,
								y : 0,
								patternUnits : "userSpaceOnUse",
								height : 1,
								width : 1
							});
							bG(E, {
								x : 0,
								y : 0
							});
							E.setAttributeNS(c.paper.xlink, "href", D[1]);
							z[l](E);
							var F = g.createElement("img");
							F.style.cssText = "position:absolute;left:-9999em;top-9999em";
							F.onload = function() {
								bG(z, {
									width : this.offsetWidth,
									height : this.offsetHeight
								});
								bG(E, {
									width : this.offsetWidth,
									height : this.offsetHeight
								});
								g.body.removeChild(this);
								c.paper.safari()
							};
							g.body[l](F);
							F.src = D[1];
							c.paper.defs[l](z);
							h.style.fill = "url(#" + z.id + ")";
							bG(h, {
								fill : "url(#" + z.id + ")"
							});
							c.pattern = z;
							c.pattern && bJ(c);
							break
						}
						var G = a.getRGB(o);
						if (G.error)
							if ((({
								circle : 1,
								ellipse : 1
							})[f](c.type) || r(o).charAt() != "r")
									&& bI(h, o, c.paper)) {
								i.gradient = o;
								i.fill = "none";
								break
							} else {
								delete d.gradient;
								delete i.gradient;
								!a.is(i.opacity, "undefined")
										&& a.is(d.opacity, "undefined")
										&& bG(h, {
											opacity : i.opacity
										});
								!a.is(i["fill-opacity"], "undefined")
										&& a.is(d["fill-opacity"], "undefined")
										&& bG(h, {
											"fill-opacity" : i["fill-opacity"]
										})
							}
						G[f]("opacity")
								&& bG(
										h,
										{
											"fill-opacity" : G.opacity > 1 ? G.opacity / 100
													: G.opacity
										});
					case "stroke":
						G = a.getRGB(o);
						h[R](n, G.hex);
						n == "stroke"
								&& G[f]("opacity")
								&& bG(
										h,
										{
											"stroke-opacity" : G.opacity > 1 ? G.opacity / 100
													: G.opacity
										});
						break;
					case "gradient":
						(({
							circle : 1,
							ellipse : 1
						})[f](c.type) || r(o).charAt() != "r")
								&& bI(h, o, c.paper);
						break;
					case "opacity":
						i.gradient && !i[f]("stroke-opacity") && bG(h, {
							"stroke-opacity" : o > 1 ? o / 100 : o
						});
					case "fill-opacity":
						if (i.gradient) {
							var H = g.getElementById(h.getAttribute(I)[Y](
									/^url\(#|\)$/g, p));
							if (H) {
								var J = H.getElementsByTagName("stop");
								J[J[w] - 1][R]("stop-opacity", o)
							}
							break
						}
					default:
						n == "font-size" && (o = T(o, 10) + "px");
						var K = n[Y](/(\-.)/g, function(a) {
							return V.call(a.substring(1))
						});
						h.style[K] = o;
						h[R](n, o);
						break
					}
				}
			}
			bM(c, d);
			m ? c.rotate(m.join(q)) : S(j) && c.rotate(j, true)
		}, bL = 1.2, bM = function(b, c) {
			if (b.type != "text"
					|| !(c[f]("text") || c[f]("font") || c[f]("font-size")
							|| c[f]("x") || c[f]("y")))
				return;
			var d = b.attrs, e = b.node, h = e.firstChild ? T(g.defaultView
					.getComputedStyle(e.firstChild, p).getPropertyValue(
							"font-size"), 10) : 10;
			if (c[f]("text")) {
				d.text = c.text;
				while (e.firstChild)
					e.removeChild(e.firstChild);
				var i = r(c.text)[s]("\n");
				for ( var j = 0, k = i[w]; j < k; j++)
					if (i[j]) {
						var m = bG("tspan");
						j && bG(m, {
							dy : h * bL,
							x : d.x
						});
						m[l](g.createTextNode(i[j]));
						e[l](m)
					}
			} else {
				i = e.getElementsByTagName("tspan");
				for (j = 0, k = i[w]; j < k; j++)
					j && bG(i[j], {
						dy : h * bL,
						x : d.x
					})
			}
			bG(e, {
				y : d.y
			});
			var n = b.getBBox(), o = d.y - (n.y + n.height / 2);
			o && a.is(o, "finite") && bG(e, {
				y : d.y + o
			})
		}, bN = function(b, c) {
			var d = 0, e = 0;
			this[0] = b;
			this.id = a._oid++;
			this.node = b;
			b.raphael = this;
			this.paper = c;
			this.attrs = this.attrs || {};
			this.transformations = [];
			this._ = {
				tx : 0,
				ty : 0,
				rt : {
					deg : 0,
					cx : 0,
					cy : 0
				},
				sx : 1,
				sy : 1
			};
			!c.bottom && (c.bottom = this);
			this.prev = c.top;
			c.top && (c.top.next = this);
			c.top = this;
			this.next = null
		}, bO = bN[e];
		bN[e].rotate = function(c, d, e) {
			if (this.removed)
				return this;
			if (c == null) {
				if (this._.rt.cx)
					return [ this._.rt.deg, this._.rt.cx, this._.rt.cy ][v](q);
				return this._.rt.deg
			}
			var f = this.getBBox();
			c = r(c)[s](b);
			if (c[w] - 1) {
				d = S(c[1]);
				e = S(c[2])
			}
			c = S(c[0]);
			d != null && d !== false ? this._.rt.deg = c : this._.rt.deg += c;
			e == null && (d = null);
			this._.rt.cx = d;
			this._.rt.cy = e;
			d = d == null ? f.x + f.width / 2 : d;
			e = e == null ? f.y + f.height / 2 : e;
			if (this._.rt.deg) {
				this.transformations[0] = a.format("rotate({0} {1} {2})",
						this._.rt.deg, d, e);
				this.clip
						&& bG(this.clip, {
							transform : a.format("rotate({0} {1} {2})",
									-this._.rt.deg, d, e)
						})
			} else {
				this.transformations[0] = p;
				this.clip && bG(this.clip, {
					transform : p
				})
			}
			bG(this.node, {
				transform : this.transformations[v](q)
			});
			return this
		};
		bN[e].hide = function() {
			!this.removed && (this.node.style.display = "none");
			return this
		};
		bN[e].show = function() {
			!this.removed && (this.node.style.display = "");
			return this
		};
		bN[e].remove = function() {
			if (this.removed)
				return;
			bA(this, this.paper);
			this.node.parentNode.removeChild(this.node);
			for ( var a in this)
				delete this[a];
			this.removed = true
		};
		bN[e].getBBox = function() {
			if (this.removed)
				return this;
			if (this.type == "path")
				return bn(this.attrs.path);
			if (this.node.style.display == "none") {
				this.show();
				var a = true
			}
			var b = {};
			try {
				b = this.node.getBBox()
			} catch (a) {
			} finally {
				b = b || {}
			}
			if (this.type == "text") {
				b = {
					x : b.x,
					y : Infinity,
					width : 0,
					height : 0
				};
				for ( var c = 0, d = this.node.getNumberOfChars(); c < d; c++) {
					var e = this.node.getExtentOfChar(c);
					e.y < b.y && (b.y = e.y);
					e.y + e.height - b.y > b.height
							&& (b.height = e.y + e.height - b.y);
					e.x + e.width - b.x > b.width
							&& (b.width = e.x + e.width - b.x)
				}
			}
			a && this.hide();
			return b
		};
		bN[e].attr = function(b, c) {
			if (this.removed)
				return this;
			if (b == null) {
				var d = {};
				for ( var e in this.attrs)
					this.attrs[f](e) && (d[e] = this.attrs[e]);
				this._.rt.deg && (d.rotation = this.rotate());
				(this._.sx != 1 || this._.sy != 1) && (d.scale = this.scale());
				d.gradient && d.fill == "none" && (d.fill = d.gradient)
						&& delete d.gradient;
				return d
			}
			if (c == null && a.is(b, F)) {
				if (b == "translation")
					return cz.call(this);
				if (b == "rotation")
					return this.rotate();
				if (b == "scale")
					return this.scale();
				if (b == I && this.attrs.fill == "none" && this.attrs.gradient)
					return this.attrs.gradient;
				return this.attrs[b]
			}
			if (c == null && a.is(b, G)) {
				var g = {};
				for ( var h = 0, i = b.length; h < i; h++)
					g[b[h]] = this.attr(b[h]);
				return g
			}
			if (c != null) {
				var j = {};
				j[b] = c
			} else
				b != null && a.is(b, "object") && (j = b);
			for ( var k in this.paper.customAttributes)
				if (this.paper.customAttributes[f](k) && j[f](k)
						&& a.is(this.paper.customAttributes[k], "function")) {
					var l = this.paper.customAttributes[k].apply(this, [][n]
							(j[k]));
					this.attrs[k] = j[k];
					for ( var m in l)
						l[f](m) && (j[m] = l[m])
				}
			bK(this, j);
			return this
		};
		bN[e].toFront = function() {
			if (this.removed)
				return this;
			this.node.parentNode[l](this.node);
			var a = this.paper;
			a.top != this && bB(this, a);
			return this
		};
		bN[e].toBack = function() {
			if (this.removed)
				return this;
			if (this.node.parentNode.firstChild != this.node) {
				this.node.parentNode.insertBefore(this.node,
						this.node.parentNode.firstChild);
				bC(this, this.paper);
				var a = this.paper
			}
			return this
		};
		bN[e].insertAfter = function(a) {
			if (this.removed)
				return this;
			var b = a.node || a[a.length - 1].node;
			b.nextSibling ? b.parentNode.insertBefore(this.node, b.nextSibling)
					: b.parentNode[l](this.node);
			bD(this, a, this.paper);
			return this
		};
		bN[e].insertBefore = function(a) {
			if (this.removed)
				return this;
			var b = a.node || a[0].node;
			b.parentNode.insertBefore(this.node, b);
			bE(this, a, this.paper);
			return this
		};
		bN[e].blur = function(a) {
			var b = this;
			if (+a !== 0) {
				var c = bG("filter"), d = bG("feGaussianBlur");
				b.attrs.blur = a;
				c.id = bh();
				bG(d, {
					stdDeviation : +a || 1.5
				});
				c.appendChild(d);
				b.paper.defs.appendChild(c);
				b._blur = c;
				bG(b.node, {
					filter : "url(#" + c.id + ")"
				})
			} else {
				if (b._blur) {
					b._blur.parentNode.removeChild(b._blur);
					delete b._blur;
					delete b.attrs.blur
				}
				b.node.removeAttribute("filter")
			}
		};
		var bP = function(a, b, c, d) {
			var e = bG("circle");
			a.canvas && a.canvas[l](e);
			var f = new bN(e, a);
			f.attrs = {
				cx : b,
				cy : c,
				r : d,
				fill : "none",
				stroke : "#000"
			};
			f.type = "circle";
			bG(e, f.attrs);
			return f
		}, bQ = function(a, b, c, d, e, f) {
			var g = bG("rect");
			a.canvas && a.canvas[l](g);
			var h = new bN(g, a);
			h.attrs = {
				x : b,
				y : c,
				width : d,
				height : e,
				r : f || 0,
				rx : f || 0,
				ry : f || 0,
				fill : "none",
				stroke : "#000"
			};
			h.type = "rect";
			bG(g, h.attrs);
			return h
		}, bR = function(a, b, c, d, e) {
			var f = bG("ellipse");
			a.canvas && a.canvas[l](f);
			var g = new bN(f, a);
			g.attrs = {
				cx : b,
				cy : c,
				rx : d,
				ry : e,
				fill : "none",
				stroke : "#000"
			};
			g.type = "ellipse";
			bG(f, g.attrs);
			return g
		}, bS = function(a, b, c, d, e, f) {
			var g = bG("image");
			bG(g, {
				x : c,
				y : d,
				width : e,
				height : f,
				preserveAspectRatio : "none"
			});
			g.setAttributeNS(a.xlink, "href", b);
			a.canvas && a.canvas[l](g);
			var h = new bN(g, a);
			h.attrs = {
				x : c,
				y : d,
				width : e,
				height : f,
				src : b
			};
			h.type = "image";
			return h
		}, bT = function(a, b, c, d) {
			var e = bG("text");
			bG(e, {
				x : b,
				y : c,
				"text-anchor" : "middle"
			});
			a.canvas && a.canvas[l](e);
			var f = new bN(e, a);
			f.attrs = {
				x : b,
				y : c,
				"text-anchor" : "middle",
				text : d,
				font : W.font,
				stroke : "none",
				fill : "#000"
			};
			f.type = "text";
			bK(f, f.attrs);
			return f
		}, bU = function(a, b) {
			this.width = a || this.width;
			this.height = b || this.height;
			this.canvas[R]("width", this.width);
			this.canvas[R]("height", this.height);
			return this
		}, bV = function() {
			var b = by[m](0, arguments), c = b && b.container, d = b.x, e = b.y, f = b.width, h = b.height;
			if (!c)
				throw new Error("SVG container not found.");
			var i = bG("svg");
			d = d || 0;
			e = e || 0;
			f = f || 512;
			h = h || 342;
			bG(i, {
				xmlns : "http://www.w3.org/2000/svg",
				version : 1.1,
				width : f,
				height : h
			});
			if (c == 1) {
				i.style.cssText = "position:absolute;left:" + d + "px;top:" + e
						+ "px";
				g.body[l](i)
			} else
				c.firstChild ? c.insertBefore(i, c.firstChild) : c[l](i);
			c = new j;
			c.width = f;
			c.height = h;
			c.canvas = i;
			bz.call(c, c, a.fn);
			c.clear();
			return c
		};
		k.clear = function() {
			var a = this.canvas;
			while (a.firstChild)
				a.removeChild(a.firstChild);
			this.bottom = this.top = null;
			(this.desc = bG("desc"))[l](g
					.createTextNode("Created with Raphaël"));
			a[l](this.desc);
			a[l](this.defs = bG("defs"))
		};
		k.remove = function() {
			this.canvas.parentNode
					&& this.canvas.parentNode.removeChild(this.canvas);
			for ( var a in this)
				this[a] = bF(a)
		}
	}
	if (a.vml) {
		var bW = {
			M : "m",
			L : "l",
			C : "c",
			Z : "x",
			m : "t",
			l : "r",
			c : "v",
			z : "x"
		}, bX = /([clmz]),?([^clmz]*)/gi, bY = / progid:\S+Blur\([^\)]+\)/g, bZ = /-?[^,\s-]+/g, b$ = 1000 + q + 1000, b_ = 10, ca = {
			path : 1,
			rect : 1
		}, cb = function(a) {
			var b = /[ahqstv]/ig, c = bq;
			r(a).match(b) && (c = bw);
			b = /[clmz]/g;
			if (c == bq && !r(a).match(b)) {
				var d = r(a)[Y](bX, function(a, b, c) {
					var d = [], e = x.call(b) == "m", f = bW[b];
					c[Y](bZ, function(a) {
						if (e && d[w] == 2) {
							f += d + bW[b == "m" ? "l" : "L"];
							d = []
						}
						d[L](Q(a * b_))
					});
					return f + d
				});
				return d
			}
			var e = c(a), f, g;
			d = [];
			for ( var h = 0, i = e[w]; h < i; h++) {
				f = e[h];
				g = x.call(e[h][0]);
				g == "z" && (g = "x");
				for ( var j = 1, k = f[w]; j < k; j++)
					g += Q(f[j] * b_) + (j != k - 1 ? "," : p);
				d[L](g)
			}
			return d[v](q)
		};
		a[H] = function() {
			return "Your browser doesn’t support SVG. Falling down to VML.\nYou are running Raphaël "
					+ this.version
		};
		bH = function(a, b) {
			var c = cd("group");
			c.style.cssText = "position:absolute;left:0;top:0;width:" + b.width
					+ "px;height:" + b.height + "px";
			c.coordsize = b.coordsize;
			c.coordorigin = b.coordorigin;
			var d = cd("shape"), e = d.style;
			e.width = b.width + "px";
			e.height = b.height + "px";
			d.coordsize = b$;
			d.coordorigin = b.coordorigin;
			c[l](d);
			var f = new bN(d, c, b), g = {
				fill : "none",
				stroke : "#000"
			};
			a && (g.path = a);
			f.type = "path";
			f.path = [];
			f.Path = p;
			bK(f, g);
			b.canvas[l](c);
			return f
		};
		bK = function(c, d) {
			c.attrs = c.attrs || {};
			var e = c.node, h = c.attrs, i = e.style, j, k = (d.x != h.x
					|| d.y != h.y || d.width != h.width || d.height != h.height || d.r != h.r)
					&& c.type == "rect", m = c;
			for ( var n in d)
				d[f](n) && (h[n] = d[n]);
			if (k) {
				h.path = cc(h.x, h.y, h.width, h.height, h.r);
				c.X = h.x;
				c.Y = h.y;
				c.W = h.width;
				c.H = h.height
			}
			d.href && (e.href = d.href);
			d.title && (e.title = d.title);
			d.target && (e.target = d.target);
			d.cursor && (i.cursor = d.cursor);
			"blur" in d && c.blur(d.blur);
			if (d.path && c.type == "path" || k)
				e.path = cb(h.path);
			d.rotation != null && c.rotate(d.rotation, true);
			if (d.translation) {
				j = r(d.translation)[s](b);
				cz.call(c, j[0], j[1]);
				if (c._.rt.cx != null) {
					c._.rt.cx += +j[0];
					c._.rt.cy += +j[1];
					c.setBox(c.attrs, j[0], j[1])
				}
			}
			if (d.scale) {
				j = r(d.scale)[s](b);
				c.scale(+j[0] || 1, +j[1] || +j[0] || 1, +j[2] || null, +j[3]
						|| null)
			}
			if ("clip-rect" in d) {
				var o = r(d["clip-rect"])[s](b);
				if (o[w] == 4) {
					o[2] = +o[2] + +o[0];
					o[3] = +o[3] + +o[1];
					var q = e.clipRect || g.createElement("div"), t = q.style, u = e.parentNode;
					t.clip = a.format("rect({1}px {2}px {3}px {0}px)", o);
					if (!e.clipRect) {
						t.position = "absolute";
						t.top = 0;
						t.left = 0;
						t.width = c.paper.width + "px";
						t.height = c.paper.height + "px";
						u.parentNode.insertBefore(q, u);
						q[l](u);
						e.clipRect = q
					}
				}
				d["clip-rect"] || e.clipRect && (e.clipRect.style.clip = p)
			}
			c.type == "image" && d.src && (e.src = d.src);
			if (c.type == "image" && d.opacity) {
				e.filterOpacity = U + ".Alpha(opacity=" + d.opacity * 100 + ")";
				i.filter = (e.filterMatrix || p) + (e.filterOpacity || p)
			}
			d.font && (i.font = d.font);
			d["font-family"]
					&& (i.fontFamily = "\""
							+ d["font-family"][s](",")[0][Y](/^['"]+|['"]+$/g,
									p) + "\"");
			d["font-size"] && (i.fontSize = d["font-size"]);
			d["font-weight"] && (i.fontWeight = d["font-weight"]);
			d["font-style"] && (i.fontStyle = d["font-style"]);
			if (d.opacity != null || d["stroke-width"] != null
					|| d.fill != null || d.stroke != null
					|| d["stroke-width"] != null || d["stroke-opacity"] != null
					|| d["fill-opacity"] != null
					|| d["stroke-dasharray"] != null
					|| d["stroke-miterlimit"] != null
					|| d["stroke-linejoin"] != null
					|| d["stroke-linecap"] != null) {
				e = c.shape || e;
				var v = e.getElementsByTagName(I)
						&& e.getElementsByTagName(I)[0], x = false;
				!v && (x = v = cd(I));
				if ("fill-opacity" in d || "opacity" in d) {
					var y = ((+h["fill-opacity"] + 1 || 2) - 1)
							* ((+h.opacity + 1 || 2) - 1)
							* ((+a.getRGB(d.fill).o + 1 || 2) - 1);
					y = A(z(y, 0), 1);
					v.opacity = y
				}
				d.fill && (v.on = true);
				if (v.on == null || d.fill == "none")
					v.on = false;
				if (v.on && d.fill) {
					var B = d.fill.match(M);
					if (B) {
						v.src = B[1];
						v.type = "tile"
					} else {
						v.color = a.getRGB(d.fill).hex;
						v.src = p;
						v.type = "solid";
						if (a.getRGB(d.fill).error && (m.type in {
							circle : 1,
							ellipse : 1
						} || r(d.fill).charAt() != "r") && bI(m, d.fill)) {
							h.fill = "none";
							h.gradient = d.fill
						}
					}
				}
				x && e[l](v);
				var C = e.getElementsByTagName("stroke")
						&& e.getElementsByTagName("stroke")[0], D = false;
				!C && (D = C = cd("stroke"));
				if (d.stroke && d.stroke != "none" || d["stroke-width"]
						|| d["stroke-opacity"] != null || d["stroke-dasharray"]
						|| d["stroke-miterlimit"] || d["stroke-linejoin"]
						|| d["stroke-linecap"])
					C.on = true;
				(d.stroke == "none" || C.on == null || d.stroke == 0 || d["stroke-width"] == 0)
						&& (C.on = false);
				var E = a.getRGB(d.stroke);
				C.on && d.stroke && (C.color = E.hex);
				y = ((+h["stroke-opacity"] + 1 || 2) - 1)
						* ((+h.opacity + 1 || 2) - 1) * ((+E.o + 1 || 2) - 1);
				var F = (S(d["stroke-width"]) || 1) * 0.75;
				y = A(z(y, 0), 1);
				d["stroke-width"] == null && (F = h["stroke-width"]);
				d["stroke-width"] && (C.weight = F);
				F && F < 1 && (y *= F) && (C.weight = 1);
				C.opacity = y;
				d["stroke-linejoin"]
						&& (C.joinstyle = d["stroke-linejoin"] || "miter");
				C.miterlimit = d["stroke-miterlimit"] || 8;
				d["stroke-linecap"]
						&& (C.endcap = d["stroke-linecap"] == "butt" ? "flat"
								: d["stroke-linecap"] == "square" ? "square"
										: "round");
				if (d["stroke-dasharray"]) {
					var G = {
						"-" : "shortdash",
						"." : "shortdot",
						"-." : "shortdashdot",
						"-.." : "shortdashdotdot",
						". " : "dot",
						"- " : "dash",
						"--" : "longdash",
						"- ." : "dashdot",
						"--." : "longdashdot",
						"--.." : "longdashdotdot"
					};
					C.dashstyle = G[f](d["stroke-dasharray"]) ? G[d["stroke-dasharray"]]
							: p
				}
				D && e[l](C)
			}
			if (m.type == "text") {
				i = m.paper.span.style;
				h.font && (i.font = h.font);
				h["font-family"] && (i.fontFamily = h["font-family"]);
				h["font-size"] && (i.fontSize = h["font-size"]);
				h["font-weight"] && (i.fontWeight = h["font-weight"]);
				h["font-style"] && (i.fontStyle = h["font-style"]);
				m.node.string
						&& (m.paper.span.innerHTML = r(m.node.string)[Y](/</g,
								"&#60;")[Y](/&/g, "&#38;")[Y](/\n/g, "<br>"));
				m.W = h.w = m.paper.span.offsetWidth;
				m.H = h.h = m.paper.span.offsetHeight;
				m.X = h.x;
				m.Y = h.y + Q(m.H / 2);
				switch (h["text-anchor"]) {
				case "start":
					m.node.style["v-text-align"] = "left";
					m.bbx = Q(m.W / 2);
					break;
				case "end":
					m.node.style["v-text-align"] = "right";
					m.bbx = -Q(m.W / 2);
					break;
				default:
					m.node.style["v-text-align"] = "center";
					break
				}
			}
		};
		bI = function(a, b) {
			a.attrs = a.attrs || {};
			var c = a.attrs, d, e = "linear", f = ".5 .5";
			a.attrs.gradient = b;
			b = r(b)[Y](bd, function(a, b, c) {
				e = "radial";
				if (b && c) {
					b = S(b);
					c = S(c);
					C(b - 0.5, 2) + C(c - 0.5, 2) > 0.25
							&& (c = y.sqrt(0.25 - C(b - 0.5, 2))
									* ((c > 0.5) * 2 - 1) + 0.5);
					f = b + q + c
				}
				return p
			});
			b = b[s](/\s*\-\s*/);
			if (e == "linear") {
				var g = b.shift();
				g = -S(g);
				if (isNaN(g))
					return null
			}
			var h = bx(b);
			if (!h)
				return null;
			a = a.shape || a.node;
			d = a.getElementsByTagName(I)[0] || cd(I);
			!d.parentNode && a.appendChild(d);
			if (h[w]) {
				d.on = true;
				d.method = "none";
				d.color = h[0].color;
				d.color2 = h[h[w] - 1].color;
				var i = [];
				for ( var j = 0, k = h[w]; j < k; j++)
					h[j].offset && i[L](h[j].offset + q + h[j].color);
				d.colors && (d.colors.value = i[w] ? i[v]() : "0% " + d.color);
				if (e == "radial") {
					d.type = "gradientradial";
					d.focus = "100%";
					d.focussize = f;
					d.focusposition = f
				} else {
					d.type = "gradient";
					d.angle = (270 - g) % 360
				}
			}
			return 1
		};
		bN = function(b, c, d) {
			var e = 0, f = 0, g = 0, h = 1;
			this[0] = b;
			this.id = a._oid++;
			this.node = b;
			b.raphael = this;
			this.X = 0;
			this.Y = 0;
			this.attrs = {};
			this.Group = c;
			this.paper = d;
			this._ = {
				tx : 0,
				ty : 0,
				rt : {
					deg : 0
				},
				sx : 1,
				sy : 1
			};
			!d.bottom && (d.bottom = this);
			this.prev = d.top;
			d.top && (d.top.next = this);
			d.top = this;
			this.next = null
		};
		bO = bN[e];
		bO.rotate = function(a, c, d) {
			if (this.removed)
				return this;
			if (a == null) {
				if (this._.rt.cx)
					return [ this._.rt.deg, this._.rt.cx, this._.rt.cy ][v](q);
				return this._.rt.deg
			}
			a = r(a)[s](b);
			if (a[w] - 1) {
				c = S(a[1]);
				d = S(a[2])
			}
			a = S(a[0]);
			c != null ? this._.rt.deg = a : this._.rt.deg += a;
			d == null && (c = null);
			this._.rt.cx = c;
			this._.rt.cy = d;
			this.setBox(this.attrs, c, d);
			this.Group.style.rotation = this._.rt.deg;
			return this
		};
		bO.setBox = function(a, b, c) {
			if (this.removed)
				return this;
			var d = this.Group.style, e = this.shape && this.shape.style
					|| this.node.style;
			a = a || {};
			for ( var g in a)
				a[f](g) && (this.attrs[g] = a[g]);
			b = b || this._.rt.cx;
			c = c || this._.rt.cy;
			var h = this.attrs, i, j, k, l;
			switch (this.type) {
			case "circle":
				i = h.cx - h.r;
				j = h.cy - h.r;
				k = l = h.r * 2;
				break;
			case "ellipse":
				i = h.cx - h.rx;
				j = h.cy - h.ry;
				k = h.rx * 2;
				l = h.ry * 2;
				break;
			case "image":
				i = +h.x;
				j = +h.y;
				k = h.width || 0;
				l = h.height || 0;
				break;
			case "text":
				this.textpath.v = [ "m", Q(h.x), ", ", Q(h.y - 2), "l",
						Q(h.x) + 1, ", ", Q(h.y - 2) ][v](p);
				i = h.x - Q(this.W / 2);
				j = h.y - this.H / 2;
				k = this.W;
				l = this.H;
				break;
			case "rect":
			case "path":
				if (this.attrs.path) {
					var m = bn(this.attrs.path);
					i = m.x;
					j = m.y;
					k = m.width;
					l = m.height
				} else {
					i = 0;
					j = 0;
					k = this.paper.width;
					l = this.paper.height
				}
				break;
			default:
				i = 0;
				j = 0;
				k = this.paper.width;
				l = this.paper.height;
				break
			}
			b = b == null ? i + k / 2 : b;
			c = c == null ? j + l / 2 : c;
			var n = b - this.paper.width / 2, o = c - this.paper.height / 2, q;
			d.left != (q = n + "px") && (d.left = q);
			d.top != (q = o + "px") && (d.top = q);
			this.X = ca[f](this.type) ? -n : i;
			this.Y = ca[f](this.type) ? -o : j;
			this.W = k;
			this.H = l;
			if (ca[f](this.type)) {
				e.left != (q = -n * b_ + "px") && (e.left = q);
				e.top != (q = -o * b_ + "px") && (e.top = q)
			} else if (this.type == "text") {
				e.left != (q = -n + "px") && (e.left = q);
				e.top != (q = -o + "px") && (e.top = q)
			} else {
				d.width != (q = this.paper.width + "px") && (d.width = q);
				d.height != (q = this.paper.height + "px") && (d.height = q);
				e.left != (q = i - n + "px") && (e.left = q);
				e.top != (q = j - o + "px") && (e.top = q);
				e.width != (q = k + "px") && (e.width = q);
				e.height != (q = l + "px") && (e.height = q)
			}
		};
		bO.hide = function() {
			!this.removed && (this.Group.style.display = "none");
			return this
		};
		bO.show = function() {
			!this.removed && (this.Group.style.display = "block");
			return this
		};
		bO.getBBox = function() {
			if (this.removed)
				return this;
			if (ca[f](this.type))
				return bn(this.attrs.path);
			return {
				x : this.X + (this.bbx || 0),
				y : this.Y,
				width : this.W,
				height : this.H
			}
		};
		bO.remove = function() {
			if (this.removed)
				return;
			bA(this, this.paper);
			this.node.parentNode.removeChild(this.node);
			this.Group.parentNode.removeChild(this.Group);
			this.shape && this.shape.parentNode.removeChild(this.shape);
			for ( var a in this)
				delete this[a];
			this.removed = true
		};
		bO.attr = function(b, c) {
			if (this.removed)
				return this;
			if (b == null) {
				var d = {};
				for ( var e in this.attrs)
					this.attrs[f](e) && (d[e] = this.attrs[e]);
				this._.rt.deg && (d.rotation = this.rotate());
				(this._.sx != 1 || this._.sy != 1) && (d.scale = this.scale());
				d.gradient && d.fill == "none" && (d.fill = d.gradient)
						&& delete d.gradient;
				return d
			}
			if (c == null && a.is(b, "string")) {
				if (b == "translation")
					return cz.call(this);
				if (b == "rotation")
					return this.rotate();
				if (b == "scale")
					return this.scale();
				if (b == I && this.attrs.fill == "none" && this.attrs.gradient)
					return this.attrs.gradient;
				return this.attrs[b]
			}
			if (this.attrs && c == null && a.is(b, G)) {
				var g, h = {};
				for (e = 0, g = b[w]; e < g; e++)
					h[b[e]] = this.attr(b[e]);
				return h
			}
			var i;
			if (c != null) {
				i = {};
				i[b] = c
			}
			c == null && a.is(b, "object") && (i = b);
			if (i) {
				for ( var j in this.paper.customAttributes)
					if (this.paper.customAttributes[f](j) && i[f](j)
							&& a.is(this.paper.customAttributes[j], "function")) {
						var k = this.paper.customAttributes[j].apply(this,
								[][n](i[j]));
						this.attrs[j] = i[j];
						for ( var l in k)
							k[f](l) && (i[l] = k[l])
					}
				i.text && this.type == "text" && (this.node.string = i.text);
				bK(this, i);
				i.gradient && (({
					circle : 1,
					ellipse : 1
				})[f](this.type) || r(i.gradient).charAt() != "r")
						&& bI(this, i.gradient);
				(!ca[f](this.type) || this._.rt.deg) && this.setBox(this.attrs)
			}
			return this
		};
		bO.toFront = function() {
			!this.removed && this.Group.parentNode[l](this.Group);
			this.paper.top != this && bB(this, this.paper);
			return this
		};
		bO.toBack = function() {
			if (this.removed)
				return this;
			if (this.Group.parentNode.firstChild != this.Group) {
				this.Group.parentNode.insertBefore(this.Group,
						this.Group.parentNode.firstChild);
				bC(this, this.paper)
			}
			return this
		};
		bO.insertAfter = function(a) {
			if (this.removed)
				return this;
			a.constructor == cC && (a = a[a.length - 1]);
			a.Group.nextSibling ? a.Group.parentNode.insertBefore(this.Group,
					a.Group.nextSibling) : a.Group.parentNode[l](this.Group);
			bD(this, a, this.paper);
			return this
		};
		bO.insertBefore = function(a) {
			if (this.removed)
				return this;
			a.constructor == cC && (a = a[0]);
			a.Group.parentNode.insertBefore(this.Group, a.Group);
			bE(this, a, this.paper);
			return this
		};
		bO.blur = function(b) {
			var c = this.node.runtimeStyle, d = c.filter;
			d = d.replace(bY, p);
			if (+b !== 0) {
				this.attrs.blur = b;
				c.filter = d + q + U + ".Blur(pixelradius=" + (+b || 1.5) + ")";
				c.margin = a.format("-{0}px 0 0 -{0}px", Q(+b || 1.5))
			} else {
				c.filter = d;
				c.margin = 0;
				delete this.attrs.blur
			}
		};
		bP = function(a, b, c, d) {
			var e = cd("group"), f = cd("oval"), g = f.style;
			e.style.cssText = "position:absolute;left:0;top:0;width:" + a.width
					+ "px;height:" + a.height + "px";
			e.coordsize = b$;
			e.coordorigin = a.coordorigin;
			e[l](f);
			var h = new bN(f, e, a);
			h.type = "circle";
			bK(h, {
				stroke : "#000",
				fill : "none"
			});
			h.attrs.cx = b;
			h.attrs.cy = c;
			h.attrs.r = d;
			h.setBox({
				x : b - d,
				y : c - d,
				width : d * 2,
				height : d * 2
			});
			a.canvas[l](e);
			return h
		};
		function cc(b, c, d, e, f) {
			return f ? a
					.format(
							"M{0},{1}l{2},0a{3},{3},0,0,1,{3},{3}l0,{5}a{3},{3},0,0,1,{4},{3}l{6},0a{3},{3},0,0,1,{4},{4}l0,{7}a{3},{3},0,0,1,{3},{4}z",
							b + f, c, d - f * 2, f, -f, e - f * 2, f * 2 - d, f
									* 2 - e)
					: a.format("M{0},{1}l{2},0,0,{3},{4},0z", b, c, d, e, -d)
		}
		bQ = function(a, b, c, d, e, f) {
			var g = cc(b, c, d, e, f), h = a.path(g), i = h.attrs;
			h.X = i.x = b;
			h.Y = i.y = c;
			h.W = i.width = d;
			h.H = i.height = e;
			i.r = f;
			i.path = g;
			h.type = "rect";
			return h
		};
		bR = function(a, b, c, d, e) {
			var f = cd("group"), g = cd("oval"), h = g.style;
			f.style.cssText = "position:absolute;left:0;top:0;width:" + a.width
					+ "px;height:" + a.height + "px";
			f.coordsize = b$;
			f.coordorigin = a.coordorigin;
			f[l](g);
			var i = new bN(g, f, a);
			i.type = "ellipse";
			bK(i, {
				stroke : "#000"
			});
			i.attrs.cx = b;
			i.attrs.cy = c;
			i.attrs.rx = d;
			i.attrs.ry = e;
			i.setBox({
				x : b - d,
				y : c - e,
				width : d * 2,
				height : e * 2
			});
			a.canvas[l](f);
			return i
		};
		bS = function(a, b, c, d, e, f) {
			var g = cd("group"), h = cd("image");
			g.style.cssText = "position:absolute;left:0;top:0;width:" + a.width
					+ "px;height:" + a.height + "px";
			g.coordsize = b$;
			g.coordorigin = a.coordorigin;
			h.src = b;
			g[l](h);
			var i = new bN(h, g, a);
			i.type = "image";
			i.attrs.src = b;
			i.attrs.x = c;
			i.attrs.y = d;
			i.attrs.w = e;
			i.attrs.h = f;
			i.setBox({
				x : c,
				y : d,
				width : e,
				height : f
			});
			a.canvas[l](g);
			return i
		};
		bT = function(b, c, d, e) {
			var f = cd("group"), g = cd("shape"), h = g.style, i = cd("path"), j = i.style, k = cd("textpath");
			f.style.cssText = "position:absolute;left:0;top:0;width:" + b.width
					+ "px;height:" + b.height + "px";
			f.coordsize = b$;
			f.coordorigin = b.coordorigin;
			i.v = a.format("m{0},{1}l{2},{1}", Q(c * 10), Q(d * 10),
					Q(c * 10) + 1);
			i.textpathok = true;
			h.width = b.width;
			h.height = b.height;
			k.string = r(e);
			k.on = true;
			g[l](k);
			g[l](i);
			f[l](g);
			var m = new bN(k, f, b);
			m.shape = g;
			m.textpath = i;
			m.type = "text";
			m.attrs.text = e;
			m.attrs.x = c;
			m.attrs.y = d;
			m.attrs.w = 1;
			m.attrs.h = 1;
			bK(m, {
				font : W.font,
				stroke : "none",
				fill : "#000"
			});
			m.setBox();
			b.canvas[l](f);
			return m
		};
		bU = function(a, b) {
			var c = this.canvas.style;
			a == +a && (a += "px");
			b == +b && (b += "px");
			c.width = a;
			c.height = b;
			c.clip = "rect(0 " + a + " " + b + " 0)";
			return this
		};
		var cd;
		g.createStyleSheet().addRule(".rvml", "behavior:url(#default#VML)");
		try {
			!g.namespaces.rvml
					&& g.namespaces
							.add("rvml", "urn:schemas-microsoft-com:vml");
			cd = function(a) {
				return g.createElement("<rvml:" + a + " class=\"rvml\">")
			}
		} catch (a) {
			cd = function(a) {
				return g
						.createElement("<"
								+ a
								+ " xmlns=\"urn:schemas-microsoft.com:vml\" class=\"rvml\">")
			}
		}
		bV = function() {
			var b = by[m](0, arguments), c = b.container, d = b.height, e, f = b.width, h = b.x, i = b.y;
			if (!c)
				throw new Error("VML container not found.");
			var k = new j, n = k.canvas = g.createElement("div"), o = n.style;
			h = h || 0;
			i = i || 0;
			f = f || 512;
			d = d || 342;
			f == +f && (f += "px");
			d == +d && (d += "px");
			k.width = 1000;
			k.height = 1000;
			k.coordsize = b_ * 1000 + q + b_ * 1000;
			k.coordorigin = "0 0";
			k.span = g.createElement("span");
			k.span.style.cssText = "position:absolute;left:-9999em;top:-9999em;padding:0;margin:0;line-height:1;display:inline;";
			n[l](k.span);
			o.cssText = a
					.format(
							"top:0;left:0;width:{0};height:{1};display:inline-block;position:relative;clip:rect(0 {0} {1} 0);overflow:hidden",
							f, d);
			if (c == 1) {
				g.body[l](n);
				o.left = h + "px";
				o.top = i + "px";
				o.position = "absolute"
			} else
				c.firstChild ? c.insertBefore(n, c.firstChild) : c[l](n);
			bz.call(k, k, a.fn);
			return k
		};
		k.clear = function() {
			this.canvas.innerHTML = p;
			this.span = g.createElement("span");
			this.span.style.cssText = "position:absolute;left:-9999em;top:-9999em;padding:0;margin:0;line-height:1;display:inline;";
			this.canvas[l](this.span);
			this.bottom = this.top = null
		};
		k.remove = function() {
			this.canvas.parentNode.removeChild(this.canvas);
			for ( var a in this)
				this[a] = bF(a);
			return true
		}
	}
	var ce = navigator.userAgent.match(/Version\\x2f(.*?)\s/);
	navigator.vendor == "Apple Computer, Inc."
			&& (ce && ce[1] < 4 || navigator.platform.slice(0, 2) == "iP") ? k.safari = function() {
		var a = this.rect(-99, -99, this.width + 99, this.height + 99).attr({
			stroke : "none"
		});
		h.setTimeout(function() {
			a.remove()
		})
	}
			: k.safari = function() {
			};
	var cf = function() {
		this.returnValue = false
	}, cg = function() {
		return this.originalEvent.preventDefault()
	}, ch = function() {
		this.cancelBubble = true
	}, ci = function() {
		return this.originalEvent.stopPropagation()
	}, cj = (function() {
		{
			if (g.addEventListener)
				return function(a, b, c, d) {
					var e = o && u[b] ? u[b] : b, g = function(e) {
						if (o && u[f](b))
							for ( var g = 0, h = e.targetTouches
									&& e.targetTouches.length; g < h; g++) {
								if (e.targetTouches[g].target == a) {
									var i = e;
									e = e.targetTouches[g];
									e.originalEvent = i;
									e.preventDefault = cg;
									e.stopPropagation = ci;
									break
								}
							}
						return c.call(d, e)
					};
					a.addEventListener(e, g, false);
					return function() {
						a.removeEventListener(e, g, false);
						return true
					}
				};
			if (g.attachEvent)
				return function(a, b, c, d) {
					var e = function(a) {
						a = a || h.event;
						a.preventDefault = a.preventDefault || cf;
						a.stopPropagation = a.stopPropagation || ch;
						return c.call(d, a)
					};
					a.attachEvent("on" + b, e);
					var f = function() {
						a.detachEvent("on" + b, e);
						return true
					};
					return f
				}
		}
	})(), ck = [], cl = function(a) {
		var b = a.clientX, c = a.clientY, d = g.documentElement.scrollTop
				|| g.body.scrollTop, e = g.documentElement.scrollLeft
				|| g.body.scrollLeft, f, h = ck.length;
		while (h--) {
			f = ck[h];
			if (o) {
				var i = a.touches.length, j;
				while (i--) {
					j = a.touches[i];
					if (j.identifier == f.el._drag.id) {
						b = j.clientX;
						c = j.clientY;
						(a.originalEvent ? a.originalEvent : a)
								.preventDefault();
						break
					}
				}
			} else
				a.preventDefault();
			b += e;
			c += d;
			f.move
					&& f.move.call(f.move_scope || f.el, b - f.el._drag.x, c
							- f.el._drag.y, b, c, a)
		}
	}, cm = function(b) {
		a.unmousemove(cl).unmouseup(cm);
		var c = ck.length, d;
		while (c--) {
			d = ck[c];
			d.el._drag = {};
			d.end
					&& d.end.call(d.end_scope || d.start_scope || d.move_scope
							|| d.el, b)
		}
		ck = []
	};
	for ( var cn = t[w]; cn--;)
		(function(b) {
			a[b] = bN[e][b] = function(c, d) {
				if (a.is(c, "function")) {
					this.events = this.events || [];
					this.events.push({
						name : b,
						f : c,
						unbind : cj(this.shape || this.node || g, b, c, d
								|| this)
					})
				}
				return this
			};
			a["un" + b] = bN[e]["un" + b] = function(a) {
				var c = this.events, d = c[w];
				while (d--)
					if (c[d].name == b && c[d].f == a) {
						c[d].unbind();
						c.splice(d, 1);
						!c.length && delete this.events;
						return this
					}
				return this
			}
		})(t[cn]);
	bO.hover = function(a, b, c, d) {
		return this.mouseover(a, c).mouseout(b, d || c)
	};
	bO.unhover = function(a, b) {
		return this.unmouseover(a).unmouseout(b)
	};
	bO.drag = function(b, c, d, e, f, h) {
		this._drag = {};
		this
				.mousedown(function(i) {
					(i.originalEvent || i).preventDefault();
					var j = g.documentElement.scrollTop || g.body.scrollTop, k = g.documentElement.scrollLeft
							|| g.body.scrollLeft;
					this._drag.x = i.clientX + k;
					this._drag.y = i.clientY + j;
					this._drag.id = i.identifier;
					c
							&& c.call(f || e || this, i.clientX + k, i.clientY
									+ j, i);
					!ck.length && a.mousemove(cl).mouseup(cm);
					ck.push({
						el : this,
						move : b,
						end : d,
						move_scope : e,
						start_scope : f,
						end_scope : h
					})
				});
		return this
	};
	bO.undrag = function(b, c, d) {
		var e = ck.length;
		while (e--)
			ck[e].el == this && (ck[e].move == b && ck[e].end == d)
					&& ck.splice(e++, 1);
		!ck.length && a.unmousemove(cl).unmouseup(cm)
	};
	k.circle = function(a, b, c) {
		return bP(this, a || 0, b || 0, c || 0)
	};
	k.rect = function(a, b, c, d, e) {
		return bQ(this, a || 0, b || 0, c || 0, d || 0, e || 0)
	};
	k.ellipse = function(a, b, c, d) {
		return bR(this, a || 0, b || 0, c || 0, d || 0)
	};
	k.path = function(b) {
		b && !a.is(b, F) && !a.is(b[0], G) && (b += p);
		return bH(a.format[m](a, arguments), this)
	};
	k.image = function(a, b, c, d, e) {
		return bS(this, a || "about:blank", b || 0, c || 0, d || 0, e || 0)
	};
	k.text = function(a, b, c) {
		return bT(this, a || 0, b || 0, r(c))
	};
	k.set = function(a) {
		arguments[w] > 1
				&& (a = Array[e].splice.call(arguments, 0, arguments[w]));
		return new cC(a)
	};
	k.setSize = bU;
	k.top = k.bottom = null;
	k.raphael = a;
	function co() {
		return this.x + q + this.y
	}
	bO.resetScale = function() {
		if (this.removed)
			return this;
		this._.sx = 1;
		this._.sy = 1;
		this.attrs.scale = "1 1"
	};
	bO.scale = function(a, b, c, d) {
		if (this.removed)
			return this;
		if (a == null && b == null)
			return {
				x : this._.sx,
				y : this._.sy,
				toString : co
			};
		b = b || a;
		!(+b) && (b = a);
		var e, f, g, h, i = this.attrs;
		if (a != 0) {
			var j = this.getBBox(), k = j.x + j.width / 2, l = j.y + j.height
					/ 2, m = B(a / this._.sx), o = B(b / this._.sy);
			c = +c || c == 0 ? c : k;
			d = +d || d == 0 ? d : l;
			var r = this._.sx > 0, s = this._.sy > 0, t = ~(~(a / B(a))), u = ~(~(b / B(b))), x = m
					* t, y = o * u, z = this.node.style, A = c + B(k - c) * x
					* (k > c == r ? 1 : -1), C = d + B(l - d) * y
					* (l > d == s ? 1 : -1), D = a * t > b * u ? o : m;
			switch (this.type) {
			case "rect":
			case "image":
				var E = i.width * m, F = i.height * o;
				this.attr({
					height : F,
					r : i.r * D,
					width : E,
					x : A - E / 2,
					y : C - F / 2
				});
				break;
			case "circle":
			case "ellipse":
				this.attr({
					rx : i.rx * m,
					ry : i.ry * o,
					r : i.r * D,
					cx : A,
					cy : C
				});
				break;
			case "text":
				this.attr({
					x : A,
					y : C
				});
				break;
			case "path":
				var G = bp(i.path), H = true, I = r ? x : m, J = s ? y : o;
				for ( var K = 0, L = G[w]; K < L; K++) {
					var M = G[K], N = V.call(M[0]);
					{
						if (N == "M" && H)
							continue;
						H = false
					}
					if (N == "A") {
						M[G[K][w] - 2] *= I;
						M[G[K][w] - 1] *= J;
						M[1] *= m;
						M[2] *= o;
						M[5] = +(t + u ? !(!(+M[5])) : !(+M[5]))
					} else if (N == "H")
						for ( var O = 1, P = M[w]; O < P; O++)
							M[O] *= I;
					else if (N == "V")
						for (O = 1, P = M[w]; O < P; O++)
							M[O] *= J;
					else
						for (O = 1, P = M[w]; O < P; O++)
							M[O] *= O % 2 ? I : J
				}
				var Q = bn(G);
				e = A - Q.x - Q.width / 2;
				f = C - Q.y - Q.height / 2;
				G[0][1] += e;
				G[0][2] += f;
				this.attr({
					path : G
				});
				break
			}
			if (this.type in {
				text : 1,
				image : 1
			} && (t != 1 || u != 1))
				if (this.transformations) {
					this.transformations[2] = "scale("[n](t, ",", u, ")");
					this.node[R]("transform", this.transformations[v](q));
					e = t == -1 ? -i.x - (E || 0) : i.x;
					f = u == -1 ? -i.y - (F || 0) : i.y;
					this.attr({
						x : e,
						y : f
					});
					i.fx = t - 1;
					i.fy = u - 1
				} else {
					this.node.filterMatrix = U
							+ ".Matrix(M11="[n]
									(t, ", M12=0, M21=0, M22=", u,
											", Dx=0, Dy=0, sizingmethod='auto expand', filtertype='bilinear')");
					z.filter = (this.node.filterMatrix || p)
							+ (this.node.filterOpacity || p)
				}
			else if (this.transformations) {
				this.transformations[2] = p;
				this.node[R]("transform", this.transformations[v](q));
				i.fx = 0;
				i.fy = 0
			} else {
				this.node.filterMatrix = p;
				z.filter = (this.node.filterMatrix || p)
						+ (this.node.filterOpacity || p)
			}
			i.scale = [ a, b, c, d ][v](q);
			this._.sx = a;
			this._.sy = b
		}
		return this
	};
	bO.clone = function() {
		if (this.removed)
			return null;
		var a = this.attr();
		delete a.scale;
		delete a.translation;
		return this.paper[this.type]().attr(a)
	};
	var cp = {}, cq = function(b, c, d, e, f, g, h, i, j) {
		var k = 0, l = 100, m = [ b, c, d, e, f, g, h, i ].join(), n = cp[m], o, p;
		!n && (cp[m] = n = {
			data : []
		});
		n.timer && clearTimeout(n.timer);
		n.timer = setTimeout(function() {
			delete cp[m]
		}, 2000);
		if (j != null) {
			var q = cq(b, c, d, e, f, g, h, i);
			l = ~(~q) * 10
		}
		for ( var r = 0; r < l + 1; r++) {
			if (n.data[j] > r)
				p = n.data[r * l];
			else {
				p = a.findDotsAtSegment(b, c, d, e, f, g, h, i, r / l);
				n.data[r] = p
			}
			r && (k += C(C(o.x - p.x, 2) + C(o.y - p.y, 2), 0.5));
			if (j != null && k >= j)
				return p;
			o = p
		}
		if (j == null)
			return k
	}, cr = function(b, c) {
		return function(d, e, f) {
			d = bw(d);
			var g, h, i, j, k = "", l = {}, m, n = 0;
			for ( var o = 0, p = d.length; o < p; o++) {
				i = d[o];
				if (i[0] == "M") {
					g = +i[1];
					h = +i[2]
				} else {
					j = cq(g, h, i[1], i[2], i[3], i[4], i[5], i[6]);
					if (n + j > e) {
						if (c && !l.start) {
							m = cq(g, h, i[1], i[2], i[3], i[4], i[5], i[6], e
									- n);
							k += [ "C", m.start.x, m.start.y, m.m.x, m.m.y,
									m.x, m.y ];
							if (f)
								return k;
							l.start = k;
							k = [ "M", m.x, m.y + "C", m.n.x, m.n.y, m.end.x,
									m.end.y, i[5], i[6] ][v]();
							n += j;
							g = +i[5];
							h = +i[6];
							continue
						}
						if (!b && !c) {
							m = cq(g, h, i[1], i[2], i[3], i[4], i[5], i[6], e
									- n);
							return {
								x : m.x,
								y : m.y,
								alpha : m.alpha
							}
						}
					}
					n += j;
					g = +i[5];
					h = +i[6]
				}
				k += i
			}
			l.end = k;
			m = b ? n : c ? l : a.findDotsAtSegment(g, h, i[1], i[2], i[3],
					i[4], i[5], i[6], 1);
			m.alpha && (m = {
				x : m.x,
				y : m.y,
				alpha : m.alpha
			});
			return m
		}
	}, cs = cr(1), ct = cr(), cu = cr(0, 1);
	bO.getTotalLength = function() {
		if (this.type != "path")
			return;
		if (this.node.getTotalLength)
			return this.node.getTotalLength();
		return cs(this.attrs.path)
	};
	bO.getPointAtLength = function(a) {
		if (this.type != "path")
			return;
		return ct(this.attrs.path, a)
	};
	bO.getSubpath = function(a, b) {
		if (this.type != "path")
			return;
		if (B(this.getTotalLength() - b) < "1e-6")
			return cu(this.attrs.path, a).end;
		var c = cu(this.attrs.path, b, 1);
		return a ? cu(c, a).end : c
	};
	a.easing_formulas = {
		linear : function(a) {
			return a
		},
		"<" : function(a) {
			return C(a, 3)
		},
		">" : function(a) {
			return C(a - 1, 3) + 1
		},
		"<>" : function(a) {
			a = a * 2;
			if (a < 1)
				return C(a, 3) / 2;
			a -= 2;
			return (C(a, 3) + 2) / 2
		},
		backIn : function(a) {
			var b = 1.70158;
			return a * a * ((b + 1) * a - b)
		},
		backOut : function(a) {
			a = a - 1;
			var b = 1.70158;
			return a * a * ((b + 1) * a + b) + 1
		},
		elastic : function(a) {
			if (a == 0 || a == 1)
				return a;
			var b = 0.3, c = b / 4;
			return C(2, -10 * a) * y.sin((a - c) * (2 * D) / b) + 1
		},
		bounce : function(a) {
			var b = 7.5625, c = 2.75, d;
			if (a < 1 / c)
				d = b * a * a;
			else if (a < 2 / c) {
				a -= 1.5 / c;
				d = b * a * a + 0.75
			} else if (a < 2.5 / c) {
				a -= 2.25 / c;
				d = b * a * a + 0.9375
			} else {
				a -= 2.625 / c;
				d = b * a * a + 0.984375
			}
			return d
		}
	};
	var cv = [], cw = function() {
		var b = +(new Date);
		for ( var c = 0; c < cv[w]; c++) {
			var d = cv[c];
			if (d.stop || d.el.removed)
				continue;
			var e = b - d.start, g = d.ms, h = d.easing, i = d.from, j = d.diff, k = d.to, l = d.t, m = d.el, n = {}, o;
			if (e < g) {
				var r = h(e / g);
				for ( var s in i)
					if (i[f](s)) {
						switch (X[s]) {
						case "along":
							o = r * g * j[s];
							k.back && (o = k.len - o);
							var t = ct(k[s], o);
							m.translate(j.sx - j.x || 0, j.sy - j.y || 0);
							j.x = t.x;
							j.y = t.y;
							m.translate(t.x - j.sx, t.y - j.sy);
							k.rot && m.rotate(j.r + t.alpha, t.x, t.y);
							break;
						case E:
							o = +i[s] + r * g * j[s];
							break;
						case "colour":
							o = "rgb("
									+ [ cy(Q(i[s].r + r * g * j[s].r)),
											cy(Q(i[s].g + r * g * j[s].g)),
											cy(Q(i[s].b + r * g * j[s].b)) ][v]
											(",") + ")";
							break;
						case "path":
							o = [];
							for ( var u = 0, x = i[s][w]; u < x; u++) {
								o[u] = [ i[s][u][0] ];
								for ( var y = 1, z = i[s][u][w]; y < z; y++)
									o[u][y] = +i[s][u][y] + r * g * j[s][u][y];
								o[u] = o[u][v](q)
							}
							o = o[v](q);
							break;
						case "csv":
							switch (s) {
							case "translation":
								var A = r * g * j[s][0] - l.x, B = r * g
										* j[s][1] - l.y;
								l.x += A;
								l.y += B;
								o = A + q + B;
								break;
							case "rotation":
								o = +i[s][0] + r * g * j[s][0];
								i[s][1] && (o += "," + i[s][1] + "," + i[s][2]);
								break;
							case "scale":
								o = [ +i[s][0] + r * g * j[s][0],
										+i[s][1] + r * g * j[s][1],
										2 in k[s] ? k[s][2] : p,
										3 in k[s] ? k[s][3] : p ][v](q);
								break;
							case "clip-rect":
								o = [];
								u = 4;
								while (u--)
									o[u] = +i[s][u] + r * g * j[s][u];
								break
							}
							break;
						default:
							var C = [].concat(i[s]);
							o = [];
							u = m.paper.customAttributes[s].length;
							while (u--)
								o[u] = +C[u] + r * g * j[s][u];
							break
						}
						n[s] = o
					}
				m.attr(n);
				m._run && m._run.call(m)
			} else {
				if (k.along) {
					t = ct(k.along, k.len * !k.back);
					m.translate(j.sx - (j.x || 0) + t.x - j.sx, j.sy
							- (j.y || 0) + t.y - j.sy);
					k.rot && m.rotate(j.r + t.alpha, t.x, t.y)
				}
				(l.x || l.y) && m.translate(-l.x, -l.y);
				k.scale && (k.scale += p);
				m.attr(k);
				cv.splice(c--, 1)
			}
		}
		a.svg && m && m.paper && m.paper.safari();
		cv[w] && setTimeout(cw)
	}, cx = function(b, c, d, e, f) {
		var g = d - e;
		c.timeouts.push(setTimeout(function() {
			a.is(f, "function") && f.call(c);
			c.animate(b, g, b.easing)
		}, e))
	}, cy = function(a) {
		return z(A(a, 255), 0)
	}, cz = function(a, b) {
		if (a == null)
			return {
				x : this._.tx,
				y : this._.ty,
				toString : co
			};
		this._.tx += +a;
		this._.ty += +b;
		switch (this.type) {
		case "circle":
		case "ellipse":
			this.attr({
				cx : +a + this.attrs.cx,
				cy : +b + this.attrs.cy
			});
			break;
		case "rect":
		case "image":
		case "text":
			this.attr({
				x : +a + this.attrs.x,
				y : +b + this.attrs.y
			});
			break;
		case "path":
			var c = bp(this.attrs.path);
			c[0][1] += +a;
			c[0][2] += +b;
			this.attr({
				path : c
			});
			break
		}
		return this
	};
	bO.animateWith = function(a, b, c, d, e) {
		for ( var f = 0, g = cv.length; f < g; f++)
			cv[f].el.id == a.id && (b.start = cv[f].start);
		return this.animate(b, c, d, e)
	};
	bO.animateAlong = cA();
	bO.animateAlongBack = cA(1);
	function cA(b) {
		return function(c, d, e, f) {
			var g = {
				back : b
			};
			a.is(e, "function") ? f = e : g.rot = e;
			c && c.constructor == bN && (c = c.attrs.path);
			c && (g.along = c);
			return this.animate(g, d, f)
		}
	}
	function cB(a, b, c, d, e, f) {
		var g = 3 * b, h = 3 * (d - b) - g, i = 1 - g - h, j = 3 * c, k = 3
				* (e - c) - j, l = 1 - j - k;
		function m(a) {
			return ((i * a + h) * a + g) * a
		}
		function n(a, b) {
			var c = o(a, b);
			return ((l * c + k) * c + j) * c
		}
		function o(a, b) {
			var c, d, e, f, j, k;
			for (e = a, k = 0; k < 8; k++) {
				f = m(e) - a;
				if (B(f) < b)
					return e;
				j = (3 * i * e + 2 * h) * e + g;
				if (B(j) < 0.000001)
					break;
				e = e - f / j
			}
			c = 0;
			d = 1;
			e = a;
			if (e < c)
				return c;
			if (e > d)
				return d;
			while (c < d) {
				f = m(e);
				if (B(f - a) < b)
					return e;
				a > f ? c = e : d = e;
				e = (d - c) / 2 + c
			}
			return e
		}
		return n(a, 1 / (200 * f))
	}
	bO.onAnimation = function(a) {
		this._run = a || 0;
		return this
	};
	bO.animate = function(c, d, e, g) {
		var h = this;
		h.timeouts = h.timeouts || [];
		if (a.is(e, "function") || !e)
			g = e || null;
		if (h.removed) {
			g && g.call(h);
			return h
		}
		var i = {}, j = {}, k = false, l = {};
		for ( var m in c)
			if (c[f](m)) {
				if (X[f](m) || h.paper.customAttributes[f](m)) {
					k = true;
					i[m] = h.attr(m);
					i[m] == null && (i[m] = W[m]);
					j[m] = c[m];
					switch (X[m]) {
					case "along":
						var n = cs(c[m]), o = ct(c[m], n * !(!c.back)), p = h
								.getBBox();
						l[m] = n / d;
						l.tx = p.x;
						l.ty = p.y;
						l.sx = o.x;
						l.sy = o.y;
						j.rot = c.rot;
						j.back = c.back;
						j.len = n;
						c.rot && (l.r = S(h.rotate()) || 0);
						break;
					case E:
						l[m] = (j[m] - i[m]) / d;
						break;
					case "colour":
						i[m] = a.getRGB(i[m]);
						var q = a.getRGB(j[m]);
						l[m] = {
							r : (q.r - i[m].r) / d,
							g : (q.g - i[m].g) / d,
							b : (q.b - i[m].b) / d
						};
						break;
					case "path":
						var t = bw(i[m], j[m]);
						i[m] = t[0];
						var u = t[1];
						l[m] = [];
						for ( var v = 0, x = i[m][w]; v < x; v++) {
							l[m][v] = [ 0 ];
							for ( var y = 1, z = i[m][v][w]; y < z; y++)
								l[m][v][y] = (u[v][y] - i[m][v][y]) / d
						}
						break;
					case "csv":
						var A = r(c[m])[s](b), B = r(i[m])[s](b);
						switch (m) {
						case "translation":
							i[m] = [ 0, 0 ];
							l[m] = [ A[0] / d, A[1] / d ];
							break;
						case "rotation":
							i[m] = B[1] == A[1] && B[2] == A[2] ? B : [ 0,
									A[1], A[2] ];
							l[m] = [ (A[0] - i[m][0]) / d, 0, 0 ];
							break;
						case "scale":
							c[m] = A;
							i[m] = r(i[m])[s](b);
							l[m] = [ (A[0] - i[m][0]) / d,
									(A[1] - i[m][1]) / d, 0, 0 ];
							break;
						case "clip-rect":
							i[m] = r(i[m])[s](b);
							l[m] = [];
							v = 4;
							while (v--)
								l[m][v] = (A[v] - i[m][v]) / d;
							break
						}
						j[m] = A;
						break;
					default:
						A = [].concat(c[m]);
						B = [].concat(i[m]);
						l[m] = [];
						v = h.paper.customAttributes[m][w];
						while (v--)
							l[m][v] = ((A[v] || 0) - (B[v] || 0)) / d;
						break
					}
				}
			}
		if (k) {
			var G = a.easing_formulas[e];
			if (!G) {
				G = r(e).match(P);
				if (G && G[w] == 5) {
					var H = G;
					G = function(a) {
						return cB(a, +H[1], +H[2], +H[3], +H[4], d)
					}
				} else
					G = function(a) {
						return a
					}
			}
			cv.push({
				start : c.start || +(new Date),
				ms : d,
				easing : G,
				from : i,
				diff : l,
				to : j,
				el : h,
				t : {
					x : 0,
					y : 0
				}
			});
			a.is(g, "function") && (h._ac = setTimeout(function() {
				g.call(h)
			}, d));
			cv[w] == 1 && setTimeout(cw)
		} else {
			var C = [], D;
			for ( var F in c)
				if (c[f](F) && Z.test(F)) {
					m = {
						value : c[F]
					};
					F == "from" && (F = 0);
					F == "to" && (F = 100);
					m.key = T(F, 10);
					C.push(m)
				}
			C.sort(be);
			C[0].key && C.unshift({
				key : 0,
				value : h.attrs
			});
			for (v = 0, x = C[w]; v < x; v++)
				cx(C[v].value, h, d / 100 * C[v].key, d / 100
						* (C[v - 1] && C[v - 1].key || 0), C[v - 1]
						&& C[v - 1].value.callback);
			D = C[C[w] - 1].value.callback;
			D && h.timeouts.push(setTimeout(function() {
				D.call(h)
			}, d))
		}
		return this
	};
	bO.stop = function() {
		for ( var a = 0; a < cv.length; a++)
			cv[a].el.id == this.id && cv.splice(a--, 1);
		for (a = 0, ii = this.timeouts && this.timeouts.length; a < ii; a++)
			clearTimeout(this.timeouts[a]);
		this.timeouts = [];
		clearTimeout(this._ac);
		delete this._ac;
		return this
	};
	bO.translate = function(a, b) {
		return this.attr({
			translation : a + " " + b
		})
	};
	bO[H] = function() {
		return "Raphaël’s object"
	};
	a.ae = cv;
	var cC = function(a) {
		this.items = [];
		this[w] = 0;
		this.type = "set";
		if (a)
			for ( var b = 0, c = a[w]; b < c; b++) {
				if (a[b] && (a[b].constructor == bN || a[b].constructor == cC)) {
					this[this.items[w]] = this.items[this.items[w]] = a[b];
					this[w]++
				}
			}
	};
	cC[e][L] = function() {
		var a, b;
		for ( var c = 0, d = arguments[w]; c < d; c++) {
			a = arguments[c];
			if (a && (a.constructor == bN || a.constructor == cC)) {
				b = this.items[w];
				this[b] = this.items[b] = a;
				this[w]++
			}
		}
		return this
	};
	cC[e].pop = function() {
		delete this[this[w]--];
		return this.items.pop()
	};
	for ( var cD in bO)
		bO[f](cD) && (cC[e][cD] = (function(a) {
			return function() {
				for ( var b = 0, c = this.items[w]; b < c; b++)
					this.items[b][a][m](this.items[b], arguments);
				return this
			}
		})(cD));
	cC[e].attr = function(b, c) {
		if (b && a.is(b, G) && a.is(b[0], "object"))
			for ( var d = 0, e = b[w]; d < e; d++)
				this.items[d].attr(b[d]);
		else
			for ( var f = 0, g = this.items[w]; f < g; f++)
				this.items[f].attr(b, c);
		return this
	};
	cC[e].animate = function(b, c, d, e) {
		(a.is(d, "function") || !d) && (e = d || null);
		var f = this.items[w], g = f, h, i = this, j;
		e && (j = function() {
			!(--f) && e.call(i)
		});
		d = a.is(d, F) ? d : j;
		h = this.items[--g].animate(b, c, d, j);
		while (g--)
			this.items[g] && !this.items[g].removed
					&& this.items[g].animateWith(h, b, c, d, j);
		return this
	};
	cC[e].insertAfter = function(a) {
		var b = this.items[w];
		while (b--)
			this.items[b].insertAfter(a);
		return this
	};
	cC[e].getBBox = function() {
		var a = [], b = [], c = [], d = [];
		for ( var e = this.items[w]; e--;) {
			var f = this.items[e].getBBox();
			a[L](f.x);
			b[L](f.y);
			c[L](f.x + f.width);
			d[L](f.y + f.height)
		}
		a = A[m](0, a);
		b = A[m](0, b);
		return {
			x : a,
			y : b,
			width : z[m](0, c) - a,
			height : z[m](0, d) - b
		}
	};
	cC[e].clone = function(a) {
		a = new cC;
		for ( var b = 0, c = this.items[w]; b < c; b++)
			a[L](this.items[b].clone());
		return a
	};
	a.registerFont = function(a) {
		if (!a.face)
			return a;
		this.fonts = this.fonts || {};
		var b = {
			w : a.w,
			face : {},
			glyphs : {}
		}, c = a.face["font-family"];
		for ( var d in a.face)
			a.face[f](d) && (b.face[d] = a.face[d]);
		this.fonts[c] ? this.fonts[c][L](b) : this.fonts[c] = [ b ];
		if (!a.svg) {
			b.face["units-per-em"] = T(a.face["units-per-em"], 10);
			for ( var e in a.glyphs)
				if (a.glyphs[f](e)) {
					var g = a.glyphs[e];
					b.glyphs[e] = {
						w : g.w,
						k : {},
						d : g.d && "M" + g.d[Y](/[mlcxtrv]/g, function(a) {
							return ({
								l : "L",
								c : "C",
								x : "z",
								t : "m",
								r : "l",
								v : "c"
							})[a] || "M"
						}) + "z"
					};
					if (g.k)
						for ( var h in g.k)
							g[f](h) && (b.glyphs[e].k[h] = g.k[h])
				}
		}
		return a
	};
	k.getFont = function(b, c, d, e) {
		e = e || "normal";
		d = d || "normal";
		c = +c || ({
			normal : 400,
			bold : 700,
			lighter : 300,
			bolder : 800
		})[c] || 400;
		if (!a.fonts)
			return;
		var g = a.fonts[b];
		if (!g) {
			var h = new RegExp("(^|\\s)" + b[Y](/[^\w\d\s+!~.:_-]/g, p)
					+ "(\\s|$)", "i");
			for ( var i in a.fonts)
				if (a.fonts[f](i)) {
					if (h.test(i)) {
						g = a.fonts[i];
						break
					}
				}
		}
		var j;
		if (g)
			for ( var k = 0, l = g[w]; k < l; k++) {
				j = g[k];
				if (j.face["font-weight"] == c
						&& (j.face["font-style"] == d || !j.face["font-style"])
						&& j.face["font-stretch"] == e)
					break
			}
		return j
	};
	k.print = function(c, d, e, f, g, h, i) {
		h = h || "middle";
		i = z(A(i || 0, 1), -1);
		var j = this.set(), k = r(e)[s](p), l = 0, m = p, n;
		a.is(f, e) && (f = this.getFont(f));
		if (f) {
			n = (g || 16) / f.face["units-per-em"];
			var o = f.face.bbox.split(b), q = +o[0], t = +o[1]
					+ (h == "baseline" ? o[3] - o[1] + +f.face.descent
							: (o[3] - o[1]) / 2);
			for ( var u = 0, v = k[w]; u < v; u++) {
				var x = u && f.glyphs[k[u - 1]] || {}, y = f.glyphs[k[u]];
				l += u ? (x.w || f.w) + (x.k && x.k[k[u]] || 0) + f.w * i : 0;
				y && y.d && j[L](this.path(y.d).attr({
					fill : "#000",
					stroke : "none",
					translation : [ l, 0 ]
				}))
			}
			j.scale(n, n, q, t).translate(c - q, d - t)
		}
		return j
	};
	a.format = function(b, c) {
		var e = a.is(c, G) ? [ 0 ][n](c) : arguments;
		b && a.is(b, F) && e[w] - 1 && (b = b[Y](d, function(a, b) {
			return e[++b] == null ? p : e[b]
		}));
		return b || p
	};
	a.ninja = function() {
		i.was ? h.Raphael = i.is : delete Raphael;
		return a
	};
	a.el = bO;
	a.st = cC[e];
	i.was ? h.Raphael = a : Raphael = a
})()